设为首页 收藏本站
查看: 878|回复: 0

[经验分享] sql索引

[复制链接]

尚未签到

发表于 2016-11-7 07:16:36 | 显示全部楼层 |阅读模式
  
 
      索引是依赖于数据或视图的一种数据库对象,它保存了针对于指定数据表或视图的键值和指针。
      索引有自己的文件名(即索引文件名),也需要占用磁盘空间
      创建索引的目的是用于提高对数据表或视图的搜索效率。
  
 
      聚集索引和非聚集索引是SQL Server中两类主要的索引,他们都是基于B_树构建起来的。

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

 
 
 




  • 聚集索引(Clustered Index)


     


      聚集索引的主要特点是:索引顺序与数据表中记录的物理顺序相同,每一个表只允许拥有一个聚集索引
      实际上,聚集索引与数据是“一体”的,其存在是以表中的记录顺序来体现。
      这是因为B_树的叶子节点存储的是实际的数据


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

 
 
 
 
     由图可以看出,聚集索引的索引指针是不相交的(这是聚集索引的主要特点),
      这是因为索引顺序与数据记录的物理顺序是一致的。
 


 
     当对一个表定义主键时,聚集索引将自动、隐式被创建。聚集索引一般是在字段值唯一的字段上创建,
      特别是在主键上创建。如果在字段值非唯一的字段上创建聚集索引,那么SQL Server将对包含此重复
      字段值的记录添加4个字节的标识符,以完成对这些重复字段值的记录进行唯一性标识。
 
 
 




  • 非聚集索引


    非聚集索引允许表中记录的物理顺序与索引顺序不相同,即非聚集索引不改变表中记录的物理顺序,
    它只是保存着指向相应记录的指针。
    一个数据表可以同时拥有一个或多个非聚集索引
    非聚集索引的叶子节点包含索引键和指向索引键对应记录的指针,而不包含实际数据
    非聚集索引的索引指针是允许相交的。


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



    DSC0001.jpg
     



    ============================================================================================================================
     
    创建聚集索引:
     
     
    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表可知,即前面的记录是性别为女的,后面的记录是性别是男的学生。



    DSC0002.jpg
     

     
    2) 对表student2的s_no字段创建聚集索引


     

    create clustered index myindex1
    on student2(s_no);
       
    对s_no创建索引后,select表后可以看出,这时表student2中的记录已经按s_no升序排列,
    这种顺序也是表student2中记录在磁盘上的物理顺序。在创建聚集索引后,每一次插入数
    据,系统都会对数据重新进行排序。因此,对那些经常插入或更新索引字段值的数据表,
    尽量不要创建聚集索引。



    DSC0003.jpg
     

      


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

    DSC0004.jpg

      
      
      下面是建student表后,系统自动在主键字段s_no上创建的索引
      
    DSC0005.jpg




     
    删除索引
    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
      




运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-296710-1-1.html 上篇帖子: 《Microsoft Sql server 2008 Internals》读书笔记--第三章Databases and Database Files(3) 下篇帖子: sql server2005
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表