SQL Server误区30日谈 第29天 有关堆碎片的误区

时间:2024-01-20 06:20:06 

误区 #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?),这个链接会以下面两种方式之一出现:

  • 如果非聚集索引所在的表是堆,那么这个链接就是一个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?

标签:堆碎片
0
投稿

猜你喜欢

  • Python利用matplotlib生成图片背景及图例透明的效果

    2023-08-22 08:35:18
  • 在Qt中正确的设置窗体的背景图片的几种方法总结

    2023-05-11 11:15:01
  • Python迭代用法实例教程

    2021-07-18 13:00:45
  • 解析Python扩展模块的加速方案

    2022-12-26 04:53:00
  • python错误:AttributeError: 'module' object has no attribute 'setdefaultencoding'问题的解决方法

    2021-09-15 16:28:22
  • 跟老齐学Python之啰嗦的除法

    2022-12-18 12:47:38
  • laravel入门知识点整理

    2023-05-31 13:42:33
  • linux/mac安装mysql忘记密码的解决办法

    2024-01-23 23:40:06
  • Ubuntu 下 vim 搭建python 环境 配置

    2022-04-27 21:25:17
  • Python3中关于cookie的创建与保存

    2023-11-29 00:29:22
  • Mysql数据库名和表名在不同系统下的大小写敏感问题

    2024-01-15 11:29:35
  • javascript 常用功能总结

    2023-07-02 03:50:17
  • python3使用python-redis-lock解决并发计算问题

    2021-05-09 16:04:18
  • mysql 索引合并的使用

    2024-01-14 05:53:39
  • ASP处理多关键词查询实例代码

    2008-11-21 17:36:00
  • 原生JS实现旋转木马式图片轮播插件

    2024-04-17 09:45:08
  • 数据库 关键字一览表

    2024-01-22 23:27:21
  • python中zip()函数遍历多个列表方法

    2022-03-09 21:40:00
  • 解决安装mysqlclient的时候出现Microsoft Visual C++ 14.0 is required报错

    2024-01-14 15:48:14
  • Seaborn数据分析NBA球员信息数据集

    2021-06-27 03:36:04
  • asp之家 网络编程 m.aspxhome.com