如何解决使用Oracle如何基于两个不同的if语句有条件地从两个不同的表中选择一列?
我需要有条件地从两个不同的if语句和两个不同的表中选择一列。简而言之,它看起来像是伪代码:
IF
TABLE_A.COLUMN_A = ‘ABC’ THEN TABLE_A.COLUMN_B
ELSE IF
TABLE_B.COLUMN_F <> 0 THEN TABLE_C.COLUMN_C
END IF
有人在Oracle sql中怎么做?
TIA
解决方法
CASE
可能会有所帮助,如果这些表之间存在某种关联(即您可以JOIN
它们(可以选择CROSS JOIN
吗?):
select case when a.column_a = 'ABC' then a.column_b
when b.column_f <> 0 then c.column_c
end
from table_a a join table_b b on ...
join table_c c on ...
where ...
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。