当前位置:  开发笔记 > 数据库 > 正文

我可以使用ON语句中的CASE子句加入ORACLE(10g)中的表(或者甚至是where子句,因为它是内连接)

如何解决《我可以使用ON语句中的CASE子句加入ORACLE(10g)中的表(或者甚至是where子句,因为它是内连接)》经验,为你挑选了1个好方法。



1> Hosam Aly..:

我认为CASE声明在连接条件下工作,但我不确定.但这对你有用吗?

select *
  from table1 a
 where a.cola1 = 'valuea1'
    or (a.cola1 = 'valuea2'
        and Exists(select 1
                     from table2 b
                    where a.cola2 = b.colb2
                      and b.colb3 = 'valueb3'
                   )
        )

编辑:这不会简单地工作吗?

select a.*
  from table1 a
  Left Outer Join table2 b On (a.cola2 = b.colb2)
 where a.cola1 = 'valuea1'
    or (a.cola1 = 'valuea2' and b.colb3 = 'valueb3')

推荐阅读
谢谢巷议
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有