gpt4 book ai didi

sql-server - 过滤索引与普通非聚集索引

转载 作者:行者123 更新时间:2023-12-04 01:09:30 24 4
gpt4 key购买 nike

我在一个表中有 2.7 亿条记录。目前我在日期列上有一个非聚集索引。 99% 的时间我使用日期 > 1/1/2008 的行..这意味着其中有 1.4 亿。我正在使用 SQL Server 2008。在这种情况下,使用过滤索引而不是普通的非聚集索引是否有益?

此外,如果我使用“日期”数据类型而不是“日期时间”,它有多大好处?

提前致谢!

最佳答案

是的,过滤后的非聚集索引将用于:

  • 查询比扫描非常少的记录,例如。有 WHERE date ='20101016'(过滤掉一天,270M 中的几条记录)。
  • 查询比扫描更大的日期范围,但触摸日期字段:SELECT COUNT(date) FROM ... WHERE date BETWEEN '20080101' AND '20090101'

仅此而已。任何更复杂的查询将使用非聚集索引,过滤或未过滤,因为它会命中 index tipping point .

总而言之,对于具有 WHERE date > '200080101' 子句的此表的一般查询,您建议的过滤非聚集索引将有所帮助...没有 .此外,即使您将 date 作为聚簇索引最左键移动(这是时间范围查询时间序列的典型组织,就像您的表一样,您应该自己考虑),从 270M 中过滤掉“仅”140M 算不上优化。

适当的索引是一个复杂的话题。我强烈建议您阅读此 MSDN 链接中的所有内容,包括所有子章节:Designing Indexes .这将为您提供最低限度的知识,以理解一些更复杂的文章,并能够从大量错误信息中辨别出胡说八道。

关于sql-server - 过滤索引与普通非聚集索引,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3947115/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com