?
?
?? ? ?索引是依赖于数据或视图的一种数据库对象,它保存了针对于指定数据表或视图的键值和指针。
?? ? ?索引有自己的文件名(即索引文件名),也需要占用磁盘空间。
?? ? ?创建索引的目的是用于提高对数据表或视图的搜索效率。
?
?
?? ? ?聚集索引和非聚集索引是SQL?Server中两类主要的索引,他们都是基于B_树构建起来的。
?? ? ? 此外,还可分为唯一索引和非唯一索引、组合索引和非组合索引等
?
?
?
聚集索引(Clustered?Index)
?
?? ? ?聚集索引的主要特点是:索引顺序与数据表中记录的物理顺序相同,每一个表只允许拥有一个聚集索引。
?? ? ?实际上,聚集索引与数据是“一体”的,其存在是以表中的记录顺序来体现。
?? ? ?这是因为B_树的叶子节点存储的是实际的数据。
?
?? ? ?下面是表student中对s_no字段创建的聚集索引:
?
?
?
?? ??由图可以看出,聚集索引的索引指针是不相交的(这是聚集索引的主要特点),
?? ? ?这是因为索引顺序与数据记录的物理顺序是一致的。
?
?
?? ? 当对一个表定义主键时,聚集索引将自动、隐式被创建。聚集索引一般是在字段值唯一的字段上创建,
?? ? ?特别是在主键上创建。如果在字段值非唯一的字段上创建聚集索引,那么SQL?Server将对包含此重复
?? ? ?字段值的记录添加4个字节的标识符,以完成对这些重复字段值的记录进行唯一性标识。
?
?
?
非聚集索引
非聚集索引允许表中记录的物理顺序与索引顺序不相同,即非聚集索引不改变表中记录的物理顺序,
它只是保存着指向相应记录的指针。
一个数据表可以同时拥有一个或多个非聚集索引。
非聚集索引的叶子节点包含索引键和指向索引键对应记录的指针,而不包含实际数据。
非聚集索引的索引指针是允许相交的。
下面是表student中对s_no字段创建的聚集索引:
?============================================================================================================================
?
创建聚集索引:
?
?
1)?通过复制student表创建student2
?
select * into student2from studentwhere s_sex='男'--创建表student2并把student中男的记录写进去insert into student2select * from studentwhere s_sex='女'--把student中女的记录写入student2表中,student2表已存在
??
?
利用select?into?语句复制表时,只能复制表的结构和数据,不能复制表上已有的约束(包括索引),故student2表不带有任何的索引。
查询student2表可知,即前面的记录是性别为女的,后面的记录是性别是男的学生。
??
2)?对表student2的s_no字段创建聚集索引
?
create clustered index myindex1on student2(s_no);
??
对s_no创建索引后,select表后可以看出,这时表student2中的记录已经按s_no升序排列,
这种顺序也是表student2中记录在磁盘上的物理顺序。在创建聚集索引后,每一次插入数
据,系统都会对数据重新进行排序。因此,对那些经常插入或更新索引字段值的数据表,
尽量不要创建聚集索引。
??
查看数据表上所有索引的实例:
??
?
下面是建student表后,系统自动在主键字段s_no上创建的索引
?
删除索引
drop?index?myindex2?on?student;
删除由primary?key?或?unique?约束创建的索引
在创建表的时候,可能设置了primary?key?或?unique?约束,这时候会自动生成与约束同名的索引。
这种索引的删除不能使用drop?index?语句来完成,但可以使用alter?table?drop?constraint语句将其删除。
?
如:
删除表student中定义primary?key?约束时创建的索引PK_student_2F36BC
(可使用sp_helpindex?获取该索引名),实现代码如下:
alter?table?student
drop?constraint?pk_student_2F36BC
?