资源预览内容
第1页 / 共4页
第2页 / 共4页
第3页 / 共4页
第4页 / 共4页
亲,该文档总共4页全部预览完了,如果喜欢就下载吧!
资源描述
一,索引的概述1,概念: 数据库索引是对数据表中一个或多个列的值进行排序的结构, 就像一本书的目录一样,索引提供了在行中快速查询特定行的能力.2,优缺点:2.1 优点 : 1,大大加快搜索数据的速度,这是引入索引的主要原因.2,创建唯一性索引, 保证数据库表中每一行数据的唯一性.3,加速表与表之间的连接, 特别是在实现数据的参考完整性方面特别有意义.4,在使用分组和排序子句进行数据检索时,同样可以减少其使用时间.2,2 缺点 : 1,索引需要占用物理空间,聚集索引占的空间更大.2,创建索引和维护索引需要耗费时间,这种时间会随着数据量的增加而增加.3,当向一个包含索引的列的数据表中添加或者修改记录时,SQL server 会修改和维护相应的索引,这样增加系统的额外开销,降低处理速度。3,索引的分类:1,按存储结构可分为:a,聚集索引:指物理存储顺序与索引顺序完全相同,它由上下两层组成,上层为索引页,下层为数据页,只有一种排序方式,因此每个表中只能创建一个聚集索引。b,非聚集索引:指存储的数据顺序一般和表的物理数据的存储结构不同。通过下表我们可以分析出:(其中在学号上建立非聚集索引)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 createuniqueclustered|nonclustered index index_name on(cloumnasc|desc,n) include (column_name,n) with(,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/code 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_allon|off,set showplan_nexton|off例子:显示表 course 的课程代号,课程类型,课程内容,并显示查询过程复制代码 代码如下:use db_student set showplan_all on select 课程代号,课程类型 课程内容 from course where 课程内容=loving2,使用 statistics io 语句语法:statistics ioon|off on 和 off 分别为显示和不显示,使用方法和上一样。维护: 1,使用 dbcc showcontig 语句, 显示指定表的数据和索引的碎片信息。当对表中进行大量修改或添加数据后,应该执行此语句查看有无碎片。语法:dbcc showcontigtable_name|table_id|view_name|view_id,index_name|index_id with fast2,使用 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 简单一些);当然还要懂得学会分析和维护索引,这样才会更好的让它为咱们服务!
网站客服QQ:2055934822
金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号