当前位置: 代码迷 >> SQL >> sql目录
  详细解决方案

sql目录

热度:123   发布时间:2016-05-05 14:01:15.0
sql索引

?

?

?? ? ?索引是依赖于数据或视图的一种数据库对象,它保存了针对于指定数据表或视图的键值和指针。

?? ? ?索引有自己的文件名(即索引文件名),也需要占用磁盘空间

?? ? ?创建索引的目的是用于提高对数据表或视图的搜索效率。

?

?

?? ? ?聚集索引和非聚集索引是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)?对表student2s_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

    ?


  相关解决方案