SQL Server索引哪些应该是群集的?

栏目: 数据库 · 发布时间: 6年前

内容简介:弗雷德里克很好地总结了这一点,而这正是金伯利·特里普所宣扬的:集群密钥应该是稳定的(永不改变),不断增加(IDENTITY INT),小而独特.在您的场景中,我宁愿将聚类键放在BIGINT列而不是VARCHAR(80)列上.首先,使用BIGINT列,可以相当容易地强制执行唯一性(如果您自己不强制执行并保证唯一性,SQL Server将为每一行添加一个4字节的“uniquefier”)并且它很多平均小于VARCHAR(80).

我在一些表上有许多索引,它们都很相似,我想知道Clustered Index是否在正确的列上.以下是两个最活跃的索引的统计数据:

Nonclustered
I3_Identity (bigint)
rows: 193,781
pages: 3821
MB: 29.85
user seeks: 463,355
user_scans: 784
user_lookups: 0
updates: 256,516

Clustered Primary Key
I3_RowId (varchar(80))
rows: 193,781
pages: 24,289
MB: 189.76
user_seeks: 2,473,413
user_scans: 958
user_lookups: 463,693
updates: 2,669,261

正如你所看到的那样,经常会寻找PK,但是i3_identity专栏的所有搜索都在对这个PK进行关键查找,所以我真的从I3_Identity的索引中获益很多吗?我应该更改为使用I3_Identity作为群集吗?这可能会产生巨大的影响,因为这个表结构在我工作的地方重复了大约10000次,所以任何帮助都会受到赞赏.

弗雷德里克很好地总结了这一点,而这正是金伯利·特里普所宣扬的:集群密钥应该是稳定的(永不改变),不断增加(IDENTITY INT),小而独特.

在您的场景中,我宁愿将聚类键放在BIGINT列而不是VARCHAR(80)列上.

首先,使用BIGINT列,可以相当容易地强制执行唯一性(如果您自己不强制执行并保证唯一性,SQL Server将为每一行添加一个4字节的“uniquefier”)并且它很多平均小于VARCHAR(80).

为什么尺寸如此重要?集群密钥也将被添加到EACH和每个非聚集索引中 – 所以如果你有很多行和很多非聚集索引,那么40-80字节对8字节可以很快成为巨大的区别.

另外,另一个性能提示:为了避免所谓的书签查找(从非聚集索引中的值通过聚类键到实际的数据叶页),SQL Server 2005引入了“包含列”的概念在您的非聚集索引中.这些都非常有用,而且经常被忽视.如果您的查询通常需要索引字段加上数据库中的一个或两个其他字段,请考虑包含这些字段以实现所谓的“覆盖索引”.再次 – 请参阅Kimberly Tripp的精彩文章 – 她是SQL Server Indexing Goddess! :-)她可以比我更好地解释那些东西……

总而言之:将您的聚类键放在一个小而稳定的独特列上 – 你会做得很好!

翻译自:https://stackoverflow.com/questions/812891/sql-server-index-which-should-be-clustered


以上所述就是小编给大家介绍的《SQL Server索引哪些应该是群集的?》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

创新者的窘境(全新修订版)

创新者的窘境(全新修订版)

克莱顿•克里斯坦森 / 胡建桥 / 中信出版社 / 2014-1-1 / 48.00元

全球商业领域中,许多企业曾叱咤风云,但面对市场变化及新技术的挑战,最终惨遭淘汰。究其原因,竟然是因为它们精于管理,信奉客户至上等传统商业观念。这就是所有企业如今都正面临的“创新者的窘境”。 在《创新者的窘境》中,管理大师克里斯坦森指出,一些看似很完美的商业动作——对主流客户所需、赢利能力最强的产品进行精准投资和技术研发——最终却很可能毁掉一家优秀的企业。他分析了计算机、汽车、钢铁等多个行业的......一起来看看 《创新者的窘境(全新修订版)》 这本书的介绍吧!

URL 编码/解码
URL 编码/解码

URL 编码/解码

MD5 加密
MD5 加密

MD5 加密工具

SHA 加密
SHA 加密

SHA 加密工具