- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
假设我在 (RetailerID, PurchaseDate, UserID
) 上对表进行集群。那就是“聚簇键”,聚簇键总是包含在所有非聚簇索引中。 https://stackoverflow.com/a/23057196/88409 https://stackoverflow.com/a/2747869/88409
接下来,我创建了一个以(RetailerID、StoreID、PurchaseDate
)为键的非聚集索引“StorePurchasesIndex”,以便更快地查找仅包含特定商店子集的查找。
第一个问题是,我是否需要将 UserID
显式包含在包含的列中,或者它是否会通过包含它的集群键隐式存在?我很确定在这种情况下我不需要显式包含 UserID
,但如果我错了请纠正我。
我真正想知道的是,如果我明确地将 UserID
作为包含列包含会发生什么。它是否会冗余地包含在索引中,一次作为集群键的一部分,然后再次作为包含的列?还是 SQL Server 识别意图并避免存储它两次,因为它已经凭借集群键包含在内?
第二个问题是,如果它不是多余的,那么明确包含它是否有好处。例如,即使集群键以排除 UserID
并重建索引的方式更改,它是否会确保将来包含 UserID
?
最佳答案
对于非聚集索引,索引键/键默认存在于根级和叶级。
此默认情况因非聚集索引的定义而异。
当您创建非唯一聚集索引时,SQL Server 将在根目录添加聚集键以使其唯一,并且它也将出现在叶级中。
当您创建唯一聚集索引时,SQL Server 不会在根级别包含聚集键,但会在叶级别包含。
所以来回答你的问题..
The first question is, do I need to explicitly include UserID as an included column, or will it be there implicitly by virtue of the clustering key including it?
是的,你是对的,你不需要在包含列表中添加 userid..
What I'm really interested in knowing is what happens if I do explicitly include UserID as an include column. Will it be included in the index redundantly, once as part of the clustering key, and again as an included column? Or does SQL Server recognize the intent and avoid storing it twice since it's already included by virtue of the clustering key?
SQL Server 足够聪明,可以忽略这一点..
The second question is, if it's not included redundant, then is there a benefit to including it explicitly.
即使添加SQL Server也会忽略该列
For example, will it ensure UserID is included in the future, even if the clustering key changes in such a way that it excludes UserID and the index is rebuilt?
您不能更改聚簇键定义,您必须删除并重新创建它,因此当聚簇键更改时,非聚簇索引会根据其定义重建,因此用户 ID 将存在
关于sql-server - 在已经是聚簇键一部分的非聚簇索引中包含 "include"列有什么影响?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38775789/
一段时间以来,我一直在做这个反复出现的噩梦(阅读 - 我的应用程序中的错误)。出于某种原因,某个计时器在我停止后继续发送“Elapsed”事件,即使 在事件本身 计时器“承认”已被禁用!检查一下: /
为了找到 2 个 git 分支的共同祖先,需要做的是: git merge-base branch another_branch 好的。但是……如果两个分支都已经 merge 了怎么办?当我在这种情况
关闭。这个问题是opinion-based .它目前不接受答案。 想改进这个问题?更新问题,以便 editing this post 可以用事实和引用来回答它. 1年前关闭。 Improve this
我想要一个相机 View ,可以将图像捕获到本地文件或让用户从本地照片库中选择图像。我想也许有人为此编写了很好的库/代码。也许我可以利用它。已经有好的了吗?谢谢。我只是避免重新发明轮子:) 最佳答案
我从 master 分支创建了一个功能分支。之后有来自功能分支的提交 [F1]。 [F1] -- Feature Branch / [M1]-[M2
我喜欢使用 .NET 进行编程,尤其是 C# 3.0、.NET 3.5 和 WPF。但我特别喜欢的是 Mono .NET 确实与平台无关。 现在我听说了 Mono 中的 Olive 项目。我找不到某种
介绍和搜索 所以我认为我犯了一个严重的错误,我很担心。我已经分析了独立负责人的论坛,我已经接近找到答案,但场景太具体,不适用于我所在的位置。如果您找到可以回答我的问题的特定主题,请链接我。 例如:Ho
我有一个类似于下图的提交图。标记为 * 的提交表示大量提交。 A* | B--------- | | C* D* master 和 cor
我喜欢使用 .NET 进行编程,尤其是 C# 3.0、.NET 3.5 和 WPF。但我特别喜欢的是 Mono .NET 确实与平台无关。 现在我听说了 Mono 中的 Olive 项目。我找不到某种
我们最近接手了一个 .NET 项目,在查看 db 后,我们在某些列中有以下内容: 1)某些列具有诸如" & etc etc 2) 有些有 标签和其他非 html 编码的标签 这些数据
你好,当我导航到应用程序中的另一个页面时出现此错误 我不知道为什么这个错误出现 #0 _AsyncCompleter.complete (dart:async/future_impl.da
我使用以下 C 算法计算数据的 CRC32: #define CRC32_POLYNOM_REVERSED 0xEDB88320 uint32 calcCrc32(uint8* buffer, u
我试图在我的一个测试中断言模型中的字段没有改变。我知道从哲学上这是不正确的,但由于我控制了我需要知道的所有变量,所以我只想检查我的数据库条目是否没有改变。 我愿意接受一个解决方案,该解决方案可以将其转
我是 GitHub 的新手。并通过 Eclipse 使用它我们是两个人在开发一个应用程序。当我在 Git shell 中检查 git status 时,我得到以下状态。 On branch maste
简单代码: std::ifstream file("file.txt"); std::string line; while(getline(file,line)) ; //exhaust file
是的,我又找不到这个 Gradle DSL 方法:'compile()' 问题。 我检查了我有: buildscript { repositories { jcenter()
HTML: articles CSS: #main_menu { float: left; padding-top: 10px; vertical-align: m
我是一名优秀的程序员,十分优秀!