sql索引

 

 

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

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

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

 

 

      聚集索引和非聚集索引是SQL Server中两类主要的索引,他们都是基于B_树构建起来的。

       此外,还可分为唯一索引和非唯一索引、组合索引和非组合索引等

 

 

 

  • 聚集索引(Clustered Index)

     

      聚集索引的主要特点是:索引顺序与数据表中记录的物理顺序相同,每一个表只允许拥有一个聚集索引

      实际上,聚集索引与数据是“一体”的,其存在是以表中的记录顺序来体现。

      这是因为B_树的叶子节点存储的是实际的数据


 

      下面是表student中对s_no字段创建的聚集索引:


sql索引

 

 

 

 

     由图可以看出,聚集索引的索引指针是不相交的(这是聚集索引的主要特点)

      这是因为索引顺序与数据记录的物理顺序是一致的。

 


 

     当对一个表定义主键时,聚集索引将自动、隐式被创建。聚集索引一般是在字段值唯一的字段上创建,

      特别是在主键上创建。如果在字段值非唯一的字段上创建聚集索引,那么SQL Server将对包含此重复

      字段值的记录添加4个字节的标识符,以完成对这些重复字段值的记录进行唯一性标识。

 

 

 

  • 非聚集索引


    非聚集索引允许表中记录的物理顺序与索引顺序不相同,即非聚集索引不改变表中记录的物理顺序,

    它只是保存着指向相应记录的指针。

    一个数据表可以同时拥有一个或多个非聚集索引

    非聚集索引的叶子节点包含索引键和指向索引键对应记录的指针,而不包含实际数据

    非聚集索引的索引指针是允许相交的。


    下面是表student中对s_no字段创建的聚集索引:



    sql索引
     


    ============================================================================================================================

     

    创建聚集索引:

     

     

    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表可知,即前面的记录是性别为女的,后面的记录是性别是男的学生。



    sql索引
     

     

    2) 对表student2s_no字段创建聚集索引


     

    create clustered index myindex1
    on student2(s_no);
     

     

    s_no创建索引后,select表后可以看出,这时表student2中的记录已经按s_no升序排列,

    这种顺序也是表student2中记录在磁盘上的物理顺序。在创建聚集索引后,每一次插入数

    据,系统都会对数据重新进行排序。因此,对那些经常插入或更新索引字段值的数据表,

    尽量不要创建聚集索引。



    sql索引
     

     

    查看数据表上所有索引的实例:
     

    sql索引

     

     

    下面是建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

     


你可能感兴趣的:(sql)