1

我在查看性能方面遇到了一些问题。特别是在不需要时执行一些昂贵的连接。我已设法将问题简化为最简单的情况,并使用 AdventureWorks 示例数据库创建了以下视图,该视图将人名和电子邮件地址组合在一起。

create view PersonDetails_View
as
select P.FirstName, P.LastName, A.EmailAddress
from Person.Person P
left outer join Person.EmailAddress A
    ON P.BusinessEntityID = A.BusinessEntityID

如果我对此视图运行以下查询:

select FirstName from PersonDetails_View

生成的查询等于:

select P.FirstName
from Person.Person P
left outer join Person.EmailAddress A
    ON P.BusinessEntityID = A.BusinessEntityID

在此查询中,执行了不必要的联接。我知道为什么会这样 - 如果每行有多个EmailAddress条目Person,结果会有所不同。但是,在这种特殊情况下,映射是 1-1,并且总是如此。有没有办法防止这种连接发生,使生成的查询等于以下?

select P.FirstName
from Person.Person P

(这个简单的案例看起来确实像微优化,但我已经正确分析并识别了不必要的连接,认为这是我的情况下的性能问题 - 我保证!)

4

2 回答 2

1

CREATE UNIQUE INDEX ix
  ON Person.EmailAddress(BusinessEntityID) 

以保证没有多个匹配项。这改变了计划。

在此处输入图像描述

在此处输入图像描述

于 2013-04-22T09:54:09.487 回答
0

您可以将此视图设置为索引视图。然后它将提高性能,并且每次从视图中获取数据时都不会加入。

由于索引视图为连接查询的结果集创建了一个单独的物理存储,以后每当您访问此视图时,它将与从单个表访问相同。

于 2013-04-22T09:49:49.083 回答