sql – 如何使用带有过滤器where子句的oracle外连接

前端之家收集整理的这篇文章主要介绍了sql – 如何使用带有过滤器where子句的oracle外连接前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
如果我写一个sql
select * 
from a,b 
where     a.id=b.id(+) 
      and b.val="test"

并且我希望b中相应记录所在的所有记录都不存在或者存在val =“test”,这是正确的查询吗?

解决方法

使用ANSI语法会好得多
SELECT *
  FROM a
       LEFT OUTER JOIN b ON( a.id = b.id and
                             b.val = 'test' )

您也可以使用Oracle的语法执行相同的操作,但它有点紧张

SELECT *
  FROM a,b
 WHERE a.id = b.id(+)
   AND b.val(+) = 'test'

请注意,在这两种情况下,我都忽略了c表,因为您没有指定连接条件.而且我假设你真的不想加入A到B然后用C生成笛卡尔积.

原文链接:https://www.f2er.com/mssql/84230.html

猜你在找的MsSQL相关文章