sqlserver非聚集索引
A. sql索引分为几类
SQL SERVER中索引类型包括的三种类型分别是
唯一索引(UNIQUE),聚集索引(CLUSTERED) ,非聚集索引(NONCLUSTERED)。
主键与唯一索引的区别
主键是一种约束,唯一索引是一种索引,两者在本质上是不同的。 主键创建后一定包含一个唯一性索引,唯一性索引并不一定就是主键。 唯一性索引列允许空值,而主键列不允许为空值。 主键列在创建时,已经默认为空值 + 唯一索引了。
主键可以被其他表引用为外键,而唯一索引不能。 一个表最多只能创建一个主键,但可以创建多个唯一索引。 主键更适合那些不容易更改的唯一标识,如自动递增列、身份证号等。 在 RBO 模式下,主键的执行计划优先级要高于唯一索引。 两者可以提高查询的速度。
B. sql 什么时候用聚集索引和非聚集索引
1
聚集索引:该索引中键值的逻辑顺序决定了表中相应行的物理顺序。
聚集索引确定表中数据的物理顺序。聚集索引类似于电话簿,后者按姓氏排列数据。由于聚集索引规定数据在表中的物理存储顺序,因此一个表只能包含一个聚集索引。但该索引可以包含多个列(组合索引),就像电话簿按姓氏和名字进行组织一样。
2
聚集索引使用注意事项
定义聚集索引键时使用的列越少越好。
•
包含大量非重复值的列。
.•
使用下列运算符返回一个范围值的查询:BETWEEN、>、>=、<
和
<=。
•
被连续访问的列。
•
回大型结果集的查询。
•
经常被使用联接或
GROUP
BY
子句的查询访问的列;一般来说,这些是外键列。对
ORDER
BY
或
GROUP
BY
子句中指定的列进行索引,可以使
SQL
Server
不必对数据进行排序,因为这些行已经排序。这样可以提高查询性能。
•
OLTP
类型的应用程序,这些程序要求进行非常快速的单行查找(一般通过主键)。应在主键上创建聚集索引。
3
聚集索引不适用于:
•
频繁更改的列
。这将导致整行移动(因为
SQL
Server
必须按物理顺序保留行中的数据值)。这一点要特别注意,因为在大数据量事务处理系统中数据是易失的。
•
宽键
。来自聚集索引的键值由所有非聚集索引作为查找键使用,因此存储在每个非聚集索引的叶条目内。
4
非聚集索引:数据存储在一个地方,索引存储在另一个地方,索引带有指针指向数据的存储位置。
非聚集索引中的项目按索引键值的顺序存储,而表中的信息按另一种顺序存储(这可以由聚集索引规定)。对于非聚集索引,可以为在表非聚集索引中查找数据时常
用的每个列创建一个非聚集索引。有些书籍包含多个索引。例如,一本介绍园艺的书可能会包含一个植物通俗名称索引,和一个植物学名索引
C. 聚集索引和 非聚集索引是只有SQL SERVER才有的概念
聚集索引
和
非聚集索引
的根本区别是表记录的排列顺序和与
索引
的排列顺序是否一致,聚集索引表记录的排列顺序与索引的排列顺序一致,优点是查询速度快,因为一旦具有第一个索引值的纪录被找到,具有连续索引值的
记录
也一定
物理
的紧跟其后。聚集索引的缺点是
对表
进行修改速度较慢,这是为了保持表中的记录的物理
顺序
与索引的顺序一致,而把记录插入到数据页的相应位置,必须在数据页中进行数据重排,降低了执行速度。建议使用聚集索引的场合为:
a.此列包含有限数目的不同值;
b.查询的结果返回一个区间的值;
c.查询的结果返回某值相同的大量结果集。
非聚集索引指定了表中记录的
逻辑顺序
,但记录的物理顺序和索引的顺序不一致,聚集索引和非聚集索引都采用了
B+树
的
结构
,但非聚集索引的叶子层并不与实际的数据页相重叠,而采用叶子层包含一个指向表中的记录在数据页中的
指针
的方式。非聚集索引比聚集索引层次多,添加记录不会引起数据顺序的重组。建议使用非聚集索引的场合为:
a.此列包含了大量数目不同的值;
b.查询的结束返回的是少量的结果集;
c.order
by
子句中使用了该列。
是sql这门语言的概念
和软件
sql
server没有直接关系!
D. SQLSERVER没有聚集索引的表都是堆表,那是说堆表包括了非聚集索引的表和没有索引的表嘛
大概可以这样理解。
严格说,没有 非聚集索引的表 这一说。只能说 表没有聚集索引 ,但不能说 非聚集索引的表。
E. sqlserver bool 非聚集索引允许重复 是否有序
这里说的聚集索引是聚簇索引吧。。。
聚簇索引即建立在聚簇上的索引,创建聚簇索引时,需要对已有表数据重新进行排序(若表中已有数据),即删除原始的表数据后再将排序结果按物理顺序插回,故聚簇索引建立完毕后,建立聚簇索引的列中的数据已经全部按序排列。
一个表中只能包含一个聚簇索引,但该索引可以包含多个列。
B-树索引中,聚簇索引的叶层就是数据页。
非聚簇索引类似书本索引,索引与数据存放在不同的物理区域,建立非聚簇索引时数据本身不进行排序。一个表中科含多个非聚簇索引。
B-树索引中,非聚簇索引的叶层仍是索引页,其以指针指向数据页实际存储位置。
唯一性索引保证表中没有两行在定义索引的列上具有重复值,ORACLE自动为主键和唯一键列创建唯一索引;主键本身就是唯一索引,反之不成立(唯一索引允许一个NULL值),唯一性索引比非唯一性索引效率高,故在一般情况下,在无重复值的列上应尽量建立唯一性索引。
若为谋个表的某个列创建了唯一索引,则即使这个列没有唯一值约束,也会被强制限制不能插入重复记录。
F. sqlserver in 查找在聚集索引和非聚集索引上面的区别
SQL
SERVER提供了两种索引:聚集索引和非聚集索引。其中聚集索引表示表中存储的数据按照索引的顺序存储,检索效率比非聚集索引高,但对数据更新影响较大。非聚集索引表示数据存储在一个地方,索引存储在另一个地方,索引带有指针指向数据的存储位置,非聚集索引检索效率比聚集索引低,但对数据更新影响较小。
聚集索引确定表中数据的物理顺序。聚集索引类似于电话簿,后者按姓氏排列数据。由于聚集索引规定数据在表中的物理存储顺序,因此一个表只能包含一个聚集索引。但该索引可以包含多个列(组合索引),就像电话簿按姓氏和名字进行组织一样。
非聚集索引中的项目按索引键值的顺序存储,而表中的信息按另一种顺序存储(这可以由聚集索引规定)。对于非聚集索引,可以为在表非聚集索引中查找数据时常用的每个列创建一个非聚集索引。有些书籍包含多个索引。例如,一本介绍园艺的书可能会包含一个植物通俗名称索引,和一个植物学名索引,因为这是读者查找信息的两种最常用的方法。
G. sqlserver怎么建立索引
--创建索引
CREATE NONCLUSTERED INDEX IX_TEST_TNAME --创建一个非聚集索引
ON TEST(TNAME) --为TEST表的TNAME字段创建索引
WITH FILLFACTOR = 30 --填充因子为30%
GO
SELECT * FROM TEST(INDEX = IX_TEST_TNAME) WHERE TNAME = 'A' --指定按‘IX_TE
H. SQL中怎么创建非聚集索引
--创建非聚集索引
createnonclusteredindexinx_entry_stock_onentry_stock_d(entry_stock_bi)
--延伸:
--创建聚集索引
createclusteredindexinx_entry_stock_bionentry_stock_d(entry_stock_bi)
--创建主键
createtableyourtable
(
idintprimarykey,
namevarchar(50)
)
--增加主键
altertableentry_stock_daddprimarykeynonclustered--主键且非聚集
(entry_stock_bi,aid)
--除此以外还可以通过SQL Server Management Studio 右击表 -》设计-》 右击列 根据右键菜单 建立主键和索引
I. sql 创建聚集索引和非聚集索引失败
你这是sqlserver的脚本在oracle跑的结果
聚集和非聚集索引是SQLSERVER里的概念,对应的ORACLE里的 可以参考了解下
SQLSERVER 里的非聚集索引 -> ORACLE里的 堆表的普通索引
SQLSERVER 里的聚集索引 -> ORACLE里的 索引组织表