博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
重建索引提高查询效率
阅读量:5957 次
发布时间:2019-06-19

本文共 1728 字,大约阅读时间需要 5 分钟。

sqlserver重建(rebuild)索引可以提高查询速度

当随着表的数据量不断增长,很多存储的数据进行了不适当的跨页(sqlserver中存储的最小单位是页,页是不不可再分的),会产生很多索引的碎片。这时候需要重建索引来提高查询性能

 

SQL Server 2005在硬盘中用8KB页面在数据库文件内存放数据。缺省情况下这些页面及其包含的数据是无组织的。为了使混乱变为有序,就要生成索引。生成索引后,就有了索引页和数据页之分:数据页用来保存用户写入的数据信息;索引页存放用于检索列的数据值清单(关键字)和索引表中该值所在纪录的地址指针。索引分为簇索引和非簇索引,簇索引实质上是将表中的数据排序,就好像是字典的索引目录。非簇索引不对数据排序,它只保存了数据的地址。向一个带簇索引的表中插入数据,当数据页达到100%时,由于页面没有空间插入新的的纪录,这时就会发生分页,SQL Server 将大约一半的数据从满页中移到空页中,从而生成两个1/2满页。这样就有大量的空的数据空间。簇索引是双向链表,在每一页的头部保存了前一页、后一页以及分页后数据移出的地址。由于新页可能在数据库文件中的任何地方,因此页面的链接不一定指向磁盘的下一个物理页。链接可能指向了另一个区域,这就形成了分块,从而减慢了系统的速度。对于带簇索引和非簇索引的表来说,非簇索引的关键字是指向簇索引的,而不是指向数据页的本身。

为了克服数据分块带来的负面影响,需要重构表的索引,这是非常费时的,因此只能在需要时进行。可以通过DBCC SHOWCONTIG来确定是否需要重构表的索引。

DBCC SHOWCONTIG(TABLE_NAME)

返回结果:

DBCC SHOWCONTIG 正在扫描 'TABLE_NAME' 表...表: 'TABLE_NAME' (128211707);索引 ID: 1,数据库 ID: 5已执行 TABLE 级别的扫描。- 扫描页数................................: 564273- 扫描区数..............................: 70543- 区切换次数..............................: 70543- 每个区的平均页数........................: 8.0- 扫描密度 [最佳计数:实际计数].......: 99.99% [70535:70544]- 逻辑扫描碎片 ..................: 0.01%- 区扫描碎片 ..................: 2.52%- 每页的平均可用字节数........................: 684.6- 平均页密度(满).....................: 91.54%DBCC 执行完毕。如果 DBCC 输出了错误信息,请与系统管理员联系。

 

最佳计数为70535,实际计数为70544,这表明该表有分块,需要重构表索引,扫描密度为100%则表示没有分块

 

 

如何查看索引的使用情况:

SELECT index_type_desc,alloc_unit_type_desc,avg_fragmentation_in_percent,fragment_count,avg_fragment_size_in_pages,page_count,record_count,avg_page_space_used_in_percent
FROM sys.dm_db_index_physical_stats(DB_ID('db_name'),OBJECT_ID('table_name),NULL,NULL,'Sampled')

 

上面的语句是查询数据库db_name的表table_name的索引使用情况。

 

查询结果中的列avg_fragment_size_in_pages值超过40%就需要重建索引

重建索引

ALTER INDEX 索引名 ON  表名 REBUILD

 

 

转载于:https://www.cnblogs.com/mengyirensheng/p/4217782.html

你可能感兴趣的文章
有序的双链表
查看>>
程序员全国不同地区,微信(面试 招聘)群。
查看>>
【干货】界面控件DevExtreme视频教程大汇总!
查看>>
闭包 !if(){}.call()
查看>>
python MySQLdb安装和使用
查看>>
Java小细节
查看>>
poj - 1860 Currency Exchange
查看>>
chgrp命令
查看>>
Java集合框架GS Collections具体解释
查看>>
洛谷 P2486 BZOJ 2243 [SDOI2011]染色
查看>>
数值积分中的辛普森方法及其误差估计
查看>>
Web service (一) 原理和项目开发实战
查看>>
跑带宽度多少合适_跑步机选购跑带要多宽,你的身体早就告诉你了
查看>>
广平县北方计算机第一届PS设计大赛
查看>>
深入理解Java的接口和抽象类
查看>>
java与xml
查看>>
Javascript异步数据的同步处理方法
查看>>
iis6 zencart1.39 伪静态规则
查看>>
SQL Server代理(3/12):代理警报和操作员
查看>>
Linux备份ifcfg-eth0文件导致的网络故障问题
查看>>