SQL Server误区30日谈 第29天 有关堆碎片的误区
程序员文章站
2023-12-12 09:22:28
误区 #29:可以通过对堆建聚集索引再drop后进行堆上的碎片整理nooooooooooooo!!! 对堆建聚集索引再dr...
误区 #29:可以通过对堆建聚集索引再drop后进行堆上的碎片整理
nooooooooooooo!!!
对堆建聚集索引再drop在我看来是除了收缩数据库之外最2的事了。
如果你通过sys.dm_db_index_physical_stats(或是老版本的dbcc showcontig)看到堆上有碎片,绝对不要通过建立聚集索引再删除聚集索引来整理堆碎片。好的做法应该是建立聚集索引之后不再删除,已经有非常多的资料阐述如何选择一个理想的聚集索引键--窄,很少变动,唯一,自增。kimberly有一篇文章对此做了一个总结:ever-increasing clustering key - the clustered index debate..........again!(注意,是基于sql server 2005版本),对此我也有一个例子:an example of a nasty cluster key。
你也可以在sql server 2008中通过alter table ... rebuild来清除堆碎片,但这个做法和建立聚集索引后再删除同样邪恶。
如果你想问为什么我对此甚有成见?好吧,那我解释一下:非聚集索引中每一行都会指向一个rid或是聚集索引键的链接(详情请看:what happens if i drop a clustered index?),这个链接会以下面两种方式之一出现:
nooooooooooooo!!!
对堆建聚集索引再drop在我看来是除了收缩数据库之外最2的事了。
如果你通过sys.dm_db_index_physical_stats(或是老版本的dbcc showcontig)看到堆上有碎片,绝对不要通过建立聚集索引再删除聚集索引来整理堆碎片。好的做法应该是建立聚集索引之后不再删除,已经有非常多的资料阐述如何选择一个理想的聚集索引键--窄,很少变动,唯一,自增。kimberly有一篇文章对此做了一个总结:ever-increasing clustering key - the clustered index debate..........again!(注意,是基于sql server 2005版本),对此我也有一个例子:an example of a nasty cluster key。
你也可以在sql server 2008中通过alter table ... rebuild来清除堆碎片,但这个做法和建立聚集索引后再删除同样邪恶。
如果你想问为什么我对此甚有成见?好吧,那我解释一下:非聚集索引中每一行都会指向一个rid或是聚集索引键的链接(详情请看:what happens if i drop a clustered index?),这个链接会以下面两种方式之一出现:
- 如果非聚集索引所在的表是堆,那么这个链接就是一个rid。
- 如果非聚集索引所在的表是聚集索引,那么这个链接就是聚集索引键。
如果你希望对此有更多了解,请看文章底部的链接。
因此不难看出,如果你希望将堆变为聚集索引,那么非聚集索引的所有rid就失效了,因此所有的非聚集索引都需要被重建。同样,如果删除聚集索引键,那么所有非聚集索引上存储的聚集索引键都会失效,因此也需要重建所有的非聚集索引。
简单点说,如果你建立再删除聚集索引后,所有的非聚集索引都会被重建两次。
如果你使用sql server 2008的alter table ... rebuild来整理堆碎片,那么同样也需要重建所有的非聚集索引,因为所有的rid都会变动。
那么,如果对于“重建”聚集索引呢?这取决于sql server的版本以及你是进行rebuild索引亦或是改变索引。一个常见的误区是对表进行分区将会改变聚集索引键,但事实上不会。对于那些会引起非聚集索引重建的操作,请看如下列表:indexes from every angle: what happens to non-clustered indexes when the table structure is changed?。
推荐阅读
-
SQL Server误区30日谈 第29天 有关堆碎片的误区
-
SQL Server误区30日谈 第14天 清除日志后会将相关的LSN填零初始化
-
SQL Server误区30日谈 第6天 有关NULL位图的三个误区
-
SQL Server误区30日谈 第19天 Truncate表的操作不会被记录到日志
-
SQL Server误区30日谈 第26天 SQL Server中存在真正的“事务嵌套”
-
SQL Server误区30日谈 第28天 有关大容量事务日志恢复模式的误区
-
SQL Server误区30日谈 第18天 有关FileStream的存储,垃圾回收以及其它
-
SQL Server误区30日谈 第1天 正在运行的事务在服务器故障转移后继续执行
-
SQL Server误区30日谈 第28天 有关大容量事务日志恢复模式的误区
-
SQL Server误区30日谈 第30天 有关备份的30个误区