加入收藏 | 设为首页 | 会员中心 | 我要投稿 PHP编程网 - 黄冈站长网 (http://www.0713zz.com/)- 数据应用、建站、人体识别、智能机器人、语音技术!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

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

发布时间:2021-03-31 10:11:17 所属栏目:MsSql教程 来源:网络整理
导读:如果我写一个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 a

如果我写一个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生成笛卡尔积.

(编辑:PHP编程网 - 黄冈站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读