gpt4 book ai didi

sql-server - SQL Server 索引 View 与连接不工作的 View 匹配

转载 作者:行者123 更新时间:2023-12-02 02:33:27 25 4
gpt4 key购买 nike

有没有人知道 SQL Server 2008 R2 何时能够自动匹配包含查询连接的索引 View (也称为物化 View )?

例如 View

select dbo.Orders.Date, dbo.OrderDetails.ProductID
from dbo.OrderDetails
join dbo.Orders on dbo.OrderDetails.OrderID = dbo.Orders.ID

无法自动匹配到完全相同的查询。当我直接从这个 View 中选择 with (noexpand) 时,我实际上得到了一个更快的查询计划,该计划对索引 View 的聚集索引进行扫描。我可以让 SQL Server 自动执行此匹配吗?我有很多查询和 View ,我不想每次都手动引用索引 View ,因为我使用的是 OR 映射器。

我使用的是 SQL Server 2008 R2 企业版。

编辑:我找到了解决方案。 SQL Server 2008 R2 不会自动匹配具有超过 2 个连接的索引 View 。可能会大大减慢优化过程。

编辑 2:在我创建问题 2 年后回顾这个问题,我认为我的结论是不正确的。物化 View 匹配是一个非常脆弱的过程,多年来我没有找到明确的规则。

当然,以下因素起作用:

  • 加入人数
  • 存在谓词
  • 在 View 和查询中加入订单

最佳答案

我不太清楚你的问题是什么;但我认为这会给你你想要的:

http://msdn.microsoft.com/en-us/library/ms181151.aspx

有很多奇怪的、看似任意的条件限制 SQL Server 何时在查询中使用 View 索引。此页面为 SQL Server 2008 记录了它们。

关于sql-server - SQL Server 索引 View 与连接不工作的 View 匹配,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2887433/

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