在sql server中的where语句后使用(+)

发布于 2024-10-11 06:52:14 字数 290 浏览 2 评论 0原文

我如何将以下 plsql 转换为 tsql。 B.STATUS(+)=1 在 tsql 中不起作用。

  Select * from A,B where A.ID=B.ID(+)
     WHERE B.STATUS(+)=1

这不会返回 mssql 中的行,因为它不理解 B.STATUS 是可选的

 Select * from A LEFT JOIN B ON A.ID=B.ID
WHERE B.STATUS=1

How can i convert following plsql to tsql. B.STATUS(+)=1 doesnt work in tsql.

  Select * from A,B where A.ID=B.ID(+)
     WHERE B.STATUS(+)=1

this doesnt return rows in mssql because it doesnt understand B.STATUS is optional

 Select * from A LEFT JOIN B ON A.ID=B.ID
WHERE B.STATUS=1

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

此生挚爱伱 2024-10-18 06:52:14

当条件应用于 WHERE 子句中的外表时,OUTER JOIN 会更改为 INNER JOIN。在 ON 子句中,它保持为 OUTER。

您需要将谓词推入“

 Select * from A LEFT JOIN B ON A.ID = B.ID AND B.STATUS=1

OR ”

 Select * from
     A LEFT JOIN
     (SELECT * FROM B WHERE B.STATUS=1) B1 ON A.ID = B1.ID

An OUTER JOIN changes to an INNER JOIN when a condition is applied to the outer table in the WHERE clause. In the ON clause, it stays as OUTER.

You need to push the predicate "in"

 Select * from A LEFT JOIN B ON A.ID = B.ID AND B.STATUS=1

OR

 Select * from
     A LEFT JOIN
     (SELECT * FROM B WHERE B.STATUS=1) B1 ON A.ID = B1.ID
瞄了个咪的 2024-10-18 06:52:14

只需将其设为 OR“(b.status = 1 OR b.status IS NULL)”

Just make it an OR "(b.status = 1 OR b.status IS NULL)"

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文