首页 > 技术文章 > 【译】索引进阶(十三):SQL SERVER中的索引碎片【下篇】

qianxingmu 2019-04-03 14:37 原文

原文链接:传送门

 

通用碎片模式

如果一个表具有多个索引,那么这些索引便具有多个索引键,因而也具有不同的顺序。通常情况下,这些索引中的一两个展示了之前描述过的升序插入模式,而其他的通常展示了随机插入模式。

升序插入模式的候选索引包括那些最左边的索引列具有如下特征的列:

  • 按年月的列,比如TransactionDate。
  • 具有身份标识属性的列
  • 一个带有NewSequentialId() 默认约束的唯一性标识列

当把插入和删除考虑进来时,五种通用的碎片模式复现了出来,它们中的四种会从索引维护中受益。本章的稍后会对其进行讲解,并在下一章“创建/修改/删除”对其进行进一步详细的分析。

升序插入-升序删除

升序插入-随机删除

随机插入-周期删除

随机插入-随机删除

大规模插入-无删除

预防和修复索引碎片和页分裂

本进阶系列的下一章节讨论了两种索引维护的选择,索引重建,它减少了外部碎片并使你能够对重建索引的页充满率进行控制,索引重新组织,它减少了外部碎片并增加了页的充满率。本章为了简便起见,我们使用了短语“重建索引”,你的特定的情况会决定索引重建,或者索引重新组织,哪个是更合适的选择。

本章最后一部分我们的目标是使你理解进行索引优化时你必须要有的目标。那个目标是:产生一个具有最佳的列覆盖率,最少数量的外部碎片,并在可见的未来最少的页分裂的索引。

第一个例子:

第二个例子:

第三个例子:

第四个例子:

结论

碎片可以是内部碎片也可以是外部碎片

内部碎片指的是索引页内部留下的空余空间。

外部碎片指的是索引页的逻辑顺序与物理存储位置的背离。

外部碎片能够减慢索引扫描的性能,但它对于基于一个索引键返回少量的数据行不产生影响。

内部碎片增加了索引的大小。

页分裂需要额外的开销并且导致了外部碎片,不必要的页分裂应该被避免。避免页分裂和外部碎片的最好方式是周期性的重建/重组织索引,以产生具有最佳页覆盖率,最少数量的外部碎片,以及在可见的将来具有最少数量页分裂数的索引。

【完】

 

推荐阅读