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

[经验分享] SQL Server--索引

[复制链接]

尚未签到

发表于 2016-10-29 09:35:36 | 显示全部楼层 |阅读模式
一,索引的概述
  
  1,概念: 数据库索引是对数据表中一个或多个列的值进行排序的结构,就像一本书的目录一样,索引提供了在行中快速查询特定行的能力.
  
   2,优缺点:
   2.1优点: 1,大大加快搜索数据的速度,这是引入索引的主要原因.
   2,创建唯一性索引,保证数据库表中每一行数据的唯一性.
   3,加速表与表之间的连接,特别是在实现数据的参考完整性方面特别有意义.
   4,在使用分组和排序子句进行数据检索时,同样可以减少其使用时间.
   2,2缺点: 1,索引需要占用物理空间,聚集索引占的空间更大.
   2,创建索引和维护索引需要耗费时间,这种时间会随着数据量的增加而增加.
   3,当向一个包含索引的列的数据表中添加或者修改记录时,SQL server 会修改和维护相应的索引,这样增加系统的额外开销,降低处理速度。
  
   3,索引的分类:
   1,按存储结构可分为:
   a,聚集索引:指物理存储顺序与索引顺序完全相同,它由上下两层组成,上层为索引页,下层为数据页,只有一种排序方式,因此每个表中只能创建一个聚集索引。
   b,非聚集索引:指存储的数据顺序一般和表的物理数据的存储结构不同。通过下表我们可以分析出:(其中在学号上建立非聚集索引)
DSC0000.jpg

2,根基索引键值是否唯一,可以判定是否为唯一索引;基于多个字段的组合创建索引的为组合索引






二,索引的操作:
  
   1,创建:(1),原则:a,只有表的所有者可以在同一个表中创建索引;
  b,每个表中只可以创建一个聚集索引;
  c,每个表中最多可以创建249个非聚集索引;
  d,在经常查询的字段上建立索引;
  e,定义text,image和bit数据类型的裂伤不能创建索引;
  f,在外键列上可以创建索引,主键上一定要有索引;
  g,在那些重复值比较多的,查询较少的列上不要建立索引。
   (2),方法:a,使用SQL server Management Studio创建索引。
  b,使用T-SQL语句中的create Index语句创建索引
  c,使用Create table或者alter Table语句为表列定义主键约束或者唯一性约束时,会自动创建主键索引和惟一索引。
   这里说说T-sql语句创建索引:
   语法:

create relational index create[unique][clustered|nonclustered]   index index_name  on<object>(cloumn[asc|desc][,……n])
[include (column_name[,……n])]
[with(<relational_index_option>[,……n])]
[onfilegroup_name]

  
   说明:1,include (column_name[,……n])指定要添加到非聚集索引的叶级别的非键列。
  2,on filegroup_name,为指定文件组创建指定索引。
   例如:在course表中,对“课程代号”列创建聚集索引zindex.
  


use db_student
create clustered index zindex on course(课程代号)

  

   2,查看索引:(1),使用SQL ServerManagement Studio查看索引信息
   (2),使用系统存储过程查询索引信息,用SP_helpindex可以返回表中的所有索引信息
   例如:查看course表的索引信息
  

use db_student
execsp_helpindex course

  
3,修改索引:
   (1),在SQL Server Management Studio 中修改索引
   (2),使用Alter Index语句修改索引
   在这里为大家举一个例子:
   在course数据表中,修改所有的索引,并指定选项
  

use db_student
alterindex all on course rebuild with (fillfactor=80,sort_in_tempdb=on,statistics_norecompute=on)

  
4,删除索引:
   (1),使用SQL Server Management Studio 删除索引
   (2),使用Drop index语句删除索引
   例如:在course表中,删除zindex索引
  

use db_student
drop index course.zindex
  




三,索引的分析和维护:
  
  
分析:
1,使用showplan 语句

  语法:set showplan_all{on|off},set showplan_next{on|off}
   例子:显示表course的课程代号,课程类型,课程内容,并显示查询过程
  

use db_student
set showplan_all on  select 课程代号,课程类型 课程内容 from course where 课程内容='loving'

  
2,使用statistics io语句
   语法:statistics io{on|off} on和off分别为显示和不显示,使用方法和上一样。
   维护: 1,使用dbcc showcontig语句,显示指定表的数据和索引的碎片信息。当对表中进行大量修改或添加数据后,应该执行此语句查看有无碎片。
   语法:dbcc showcontig[{table_name|table_id|view_name|view_id},index_name|index_id] with fast
   2,使用dbcc dbreindex语句,意思是重建数据库中表的一个或多个索引。
   语法:

dbcc dbreindex
(['database.owner.table_name'[,index_name[,fillfactor]]])  [withno_infomsgs]
  说明: database.owner.table_name,重新建立索引的表名
   index_name,是要重建的索引名
  fillfactor,要创建索引时每个索引页上要用于存储数据的空间百分比。
  with no_infomsgs,禁止显示所有信息性消息
  
   3,使用dbcc indexdefrag,整理指定的表或视图的聚集索引和辅助索引碎片。
   语法:

dbcc  indexdefrag
({database_name|database_id|0},{table_name|table_id|'view_name'|view_id},{index_name|index_id})
with no_infomsgs                  

  
总结,只有我们对索引有了充分了熟悉;我们掌握了索引的增删改查四项基本操作,学会利用SQL Server ManagerSdudio去实现这些功能,和学会利用T-SQL语句去实现(自我感觉利用SQL Server Manager Sdudio 简单一些);当然还要懂得学会分析和维护索引,这样才会更好的让它为咱们服务!

运维网声明 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-292752-1-1.html 上篇帖子: SQL Server常用SQL 下篇帖子: Server SQL Modes
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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