技巧4:确定碎裂的索引 确认索引碎片的主要SQL Server命令是DBCC SHOWCONTIG。下面这个示例代码是用来确定Pubs数据库中的Authors表的索引碎片的: USE Pubs GO DBCC SHOWCONTIG (‘Authors’) GO 确定Pubs数据库中的Authors表的聚簇索引的索引碎片,可以执行下面的命令: USE Pubs GO DBCC SHOWCONTIG (‘Authors’,1) GO 作为一个引用点,1值显示聚簇索引。2到255值……
我们一直都在努力坚持原创.......请不要一声不吭,就悄悄拿走。
我原创,你原创,我们的内容世界才会更加精彩!
【所有原创内容版权均属TechTarget,欢迎大家转发分享。但未经授权,严禁任何媒体(平面媒体、网络媒体、自媒体等)以及微信公众号复制、转载、摘编或以其他方式进行使用。】
微信公众号
TechTarget
官方微博
TechTarget中国
技巧4:确定碎裂的索引
确认索引碎片的主要SQL Server命令是DBCC SHOWCONTIG。下面这个示例代码是用来确定Pubs数据库中的Authors表的索引碎片的:
USE Pubs GO DBCC SHOWCONTIG ('Authors') GO |
确定Pubs数据库中的Authors表的聚簇索引的索引碎片,可以执行下面的命令:
USE Pubs GO DBCC SHOWCONTIG ('Authors',1) GO |
作为一个引用点,1值显示聚簇索引。2到255值显示一个具体的非聚簇索引。
确定是否重建索引的一条经验法则是看扫描密度是否低于90%。
要根据技巧1来理解我们的数据:如果注意到特定的表总是有较低的扫描密度的,那么可以考虑将填充因数和pad_index降低5%到10%以减少碎片。
随着数据的增长,会造成数据库增大和事务运行时间的增长,维护窗口每一秒都会有计数。利用我们的备份服务器或将一个最近的生产数据库备份恢复到一个开发/测试服务器,然后执行DBCC命令。这样我们就可以及时地查看数据库碎片情况,从而维护窗口就可以只集中在重建的索引上。一旦我们有了这个数据,我们就可以执行技巧4上所列出的命令中的一个来重建碎裂的索引。然后,重新执行DBCC SHOWCONTIG来验证索引碎片是否已经修正。这将可以验证我们的脚本,并且粗略估计生产系统所需要的时间。
技巧5:重建碎裂的索引
索引维护是一个用来保证索引最佳配置的关键。“Index rebuild options”表概括了用来维护索引的典型方法。
Index rebuild options | |||
ID | Description | Recommendations | Sample code |
1 | 执行:当系统没有用户时,当表的索引变化要求删除旧的索引并用新的索引配置替代时,当表的聚簇索引发生变化时,因为所有非聚簇索引都依赖于聚簇索引,所以它们需要重建。 | USE PUBS GO DROP INDEX Authors.au_id_ind GO
CREATE CLUSTERED INDEX au_id_ind ON authors (au_id) GO
| |
2 | 执行:当系统没有用户时,当表之间存在引用完整性并且需要维护时,当索引配置修改聚簇索引所需要的填充因数时,它支持一个原子事务,以保证不会丢失任何索引。 | USE Pubs GO DBCC DBREINDEX (Authors, '', 70) GO
| |
3 | 当系统没有用户时执行。用以清除一个索引的碎片。 | USE Pubs GO DBCC INDEXDEFRAG (Pubs, Authors, au_id_ind GO
|
技巧6:配置数据库
与索引碎片相关的是磁盘级碎片,它是由文件删除和逻辑磁盘文件系统重组所造成的非连续文件系统,它会降低I/O敏感进程的性能。下面的建议可以最小化磁盘级碎片:
总结
索引碎片对高性能的数据库是至关重要的。确认有益的索引并不断维护它们将保证整个应用过程中的高性能。祝你好运!
翻译
TechTarget中国特约技术编辑,某高校计算机科学专业教师和网络实验室负责人,曾任职某网络国际厂商,关注数据中心、开发运维、数据库及软件开发技术。有多本关于思科数据中心和虚拟化技术的译著,如《思科绿色数据中心建设与管理》和《基于IP的能源管理》等。
相关推荐
-
SQL Server视图:创建索引和添加基础数据
你可以通过在你的SQL Server数据库中应用视图来获得很多东西。它们易于创建和使用。如果你能写一条SELECT语句,那么你就可以定义一个视图。
-
分析SQL Server级联删除的实现
SQL Server 2000与Oracle 8i相比,SQL Server级联删除有太多的限制,本文就为您介绍SQLServer级联删除的实现方法,供您参考。
-
从SQL Server中的数据更新到Oracle表中
我有两个客户端服务程序。一个用的是Oracle7数据库,而另一个用的是SQL Server 2000。现在我想把SQL Server 2000中的某些表数据更新到Oracle数据库表中……
-
在SQL Server 2000的视图中小心使用*符号(一)
有些朋友看到这个标题可能会有疑问,难道在视图中使用*符号还有何要注意的地方吗?对于这个问题,我们先不必回答,先看一下文中的例子吧。