我有一个由业务对象网络智能针对预算系统的 SQL 服务器数据库生成的大量查询。报表开发人员在 GUI 中创建了此查询,但发现它永远不会完成。我让它在昨晚运行,在我们的服务器重新启动以进行 Windows 更新之前运行了 7 个小时。
我查看了 sql 中的解释计划,并在几个“嵌套循环(内部连接)”步骤中发现了一些警告 - 其中两个警告进入第三步到最后一步。警告是“无连接谓词”。
我对此的另一个注意事项是查询在 where 子句中包含此内容:
BF_FUND.CD IN ('0105','0101')
如果你只在那里放一个基金代码,它运行良好 - 所以以某种方式添加第二个代码会使我们的事情变得笛卡尔(也许,这就是没有连接谓词会发生的情况)。
有关如何跟踪此问题的任何建议? 790 行精彩的 SQL 需要经过,只有加入后加入。
解释计划能否指向特定领域?
谢谢你的协助。
编辑:
无法发布查询,安全性的东西,而且混淆起来太大了。我不想让任何人看到它。
最佳答案
使用在线 SQL 格式化程序来清楚地了解您的 SQL 连接;然后逐块拆分查询以调试问题。
http://www.dpriver.com/pp/sqlformat.htm
然后就可以在mssql server中使用plan的图形化 View 了;这将解释一切。
P.S:如果由于没有连接谓词的嵌套循环连接而导致查询性能不佳,则不一定是在查询中缺少连接条件。
查询 http://sqlserverselect.blogspot.com/2010/10/nested-loops-join-no-join-predicate.html
关于sql-server - 如何找到 'No Join Predicate' 的来源,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7744628/