本文介绍了如何根据输入变量运行不同的查询?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我必须根据传入变量的值从单个表返回不同的列。
我已尝试使用CASE语句,但不起作用。是否有办法实现此逻辑?
select
case
when :var1='A1' then (select variable,value1,value2 from table where variable='A1')
when :var1='A2' then (select variable,value3,value4 from table where variable='A2')
end
from dual;
推荐答案
将案例移至SELECT:
SELECT someVariable AS VARIABLE_NAME,
CASE someVariable
WHEN 'A1' THEN VALUE1
WHEN 'A2' THEN VALUE3
ELSE NULL
END AS FIRST_VALUE,
CASE someVariable
WHEN 'A1' THEN VALUE3
WHEN 'A2' THEN VALUE4
ELSE NULL
END AS SECOND_VALUE
FROM TABLE
这篇关于如何根据输入变量运行不同的查询?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!