索引是依赖于数据或视图的一种数据库对象,它保存了针对于指定数据表或视图的键值和指针。
索引有自己的文件名(即索引文件名),也需要占用磁盘空间。
创建索引的目的是用于提高对数据表或视图的搜索效率。
聚集索引和非聚集索引是SQL Server中两类主要的索引,他们都是基于B_树构建起来的。
此外,还可分为唯一索引和非唯一索引、组合索引和非组合索引等
聚集索引的主要特点是:索引顺序与数据表中记录的物理顺序相同,每一个表只允许拥有一个聚集索引。
实际上,聚集索引与数据是“一体”的,其存在是以表中的记录顺序来体现。
这是因为B_树的叶子节点存储的是实际的数据。
下面是表student中对s_no字段创建的聚集索引:
由图可以看出,聚集索引的索引指针是不相交的(这是聚集索引的主要特点),
这是因为索引顺序与数据记录的物理顺序是一致的。
当对一个表定义主键时,聚集索引将自动、隐式被创建。聚集索引一般是在字段值唯一的字段上创建,
特别是在主键上创建。如果在字段值非唯一的字段上创建聚集索引,那么SQL Server将对包含此重复
字段值的记录添加4个字节的标识符,以完成对这些重复字段值的记录进行唯一性标识。
非聚集索引
非聚集索引允许表中记录的物理顺序与索引顺序不相同,即非聚集索引不改变表中记录的物理顺序,
它只是保存着指向相应记录的指针。
一个数据表可以同时拥有一个或多个非聚集索引。
非聚集索引的叶子节点包含索引键和指向索引键对应记录的指针,而不包含实际数据。
非聚集索引的索引指针是允许相交的。
下面是表student中对s_no字段创建的聚集索引:
============================================================================================================================
创建聚集索引:
1) 通过复制student表创建student2
select * into student2
from student
where s_sex='男'
--创建表student2并把student中男的记录写进去
insert into student2
select *
from student
where s_sex='女'
--把student中女的记录写入student2表中,student2表已存在
利用select into 语句复制表时,只能复制表的结构和数据,不能复制表上已有的约束(包括索引),故student2表不带有任何的索引。
查询student2表可知,即前面的记录是性别为女的,后面的记录是性别是男的学生。
2) 对表student2的s_no字段创建聚集索引
create clustered index myindex1
on 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
|