我在查看性能方面遇到了一些问题。特别是在不需要时执行一些昂贵的连接。我已设法将问题简化为最简单的情况,并使用 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
(这个简单的案例看起来确实像微优化,但我已经正确分析并识别了不必要的连接,认为这是我的情况下的性能问题 - 我保证!)