gpt4 book ai didi

sql-server - 如何找到 'No Join Predicate' 的来源

转载 作者:行者123 更新时间:2023-12-03 15:13:19 25 4
gpt4 key购买 nike

我有一个由业务对象网络智能针对预算系统的 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/

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