6

我希望您能帮助我讨论如何使用通用方法避免过多的连接。对此有一般规则吗?

目前,我有一个非常复杂的查询,它连接了 11 个表,性能很差(即使有索引和更新的统计信息)。使用 Entity Framework Profiler,我收到了减少连接数量的建议,而是执行几个单独的查询:link

每个连接都需要数据库执行额外的工作,并且查询的复杂性和成本随着每个额外的连接而迅速增长。虽然关系数据库已针对处理连接进行了优化,但执行多个单独的查询通常比执行包含多个连接的单个查询更有效。

我应该如何修改以下示例以获得更好的性能?

select  *
from   Blogs blog0_
       inner join Posts posts1_
         on blog0_.Id = posts1_.BlogId
       inner join Comments comments2_
         on posts1_.Id = comments2_.PostId
       inner join Users user3_
         on posts1_.UserId = user3_.Id
       inner join UsersBlogs users4_
         on blog0_.Id = users4_.BlogId
       inner join Users user5_
         on users4_.UserId = user5_.Id
4

1 回答 1

5

有几种方法可以最小化(优化)表连接的数量:-

  • 确保您想要什么以及需要哪些表格。
  • 还要确保表格是规范化的形式。

使用以下方法封装少量连接:-

  • 使用 CTE
  • 使用临时表
  • 意见

您可以从链接Common Table ExpressionView找到有关 CTE 和 Temp 表的详细信息 。对于临时表,只需在表名前添加“#”并从连接中插入所需的数据,然后在同一会话中使用它。

于 2016-08-22T10:14:22.700 回答