多个复合索引与单个非聚集列存储索引

如何解决多个复合索引与单个非聚集列存储索引

我们有一个 OLTP 系统,我们有一个网格,其中包含来自多个表的近 20 列。基于搜索参数加载的网格涉及大约 6 列。数据量很大,有 1 亿行来自后台表。

为了提高网格加载的性能,我们创建了具有单个唯一聚集索引的索引视图。我们目前想看看如何提高搜索参数的性能a,b,c,d,e,f

搜索可以基于任何组合:(a),(a,c),(d,e),c) ... (a,f)

我们正在考虑选择以下选项之一:

  • 索引视图上的多个复合索引具有特定的访问模式,例如 (a,b)、(b,d)、(a,c) 等。
  • 索引视图上的单个非聚集列存储索引,这将有助于满足所有不同的访问模式,如 (a,c) 等,包含的列为 20列

你能提出建议,哪种方法更好?

UPDATE:刚刚读到,非聚集列存储索引不支持包含列。将进一步尝试并更新答案,无论是通过评论,如果问题已关闭或通过回答。

解决方法

由于要考虑的组合太多,您将需要很多索引。

因此,我最多会为一些流行的列做单列或两列索引(取决于第一列的选择性)。任何更宽的东西都是浪费时间,因为索引将是选择性的。

您绝对可以在非聚集索引上做 INCLUDE 列。在这种情况下,只有将那些列带回来才值得,否则无论如何都需要进行键查找。

您还应该在查询中考虑类似 OPTION (RECOMPILE) 的内容。请参阅亚伦·伯特兰 (Aaron Bertrand) 的#BackToBasics: An Updated Kitchen Sink Example

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?