问题描述
我有查询像:
如果满足条件,如何返回两列?
select case when 1 in (1,2,3) then (select 'abc' as "name 1",'xyz' as "name 2" from dual) else 'pqr' end from dual;复制
如果满足条件,如何返回两列?
专家解答
简短的答案是你不能。更长的答案是你可以做这样的事情:
-用已知的分隔符将所有列连接成一列。然后把它们分开
-将值加载到XML文档并根据需要提取
等等。
但是这些都很麻烦。它通常更容易有两个案例表达式,第二个返回null在else:
-用已知的分隔符将所有列连接成一列。然后把它们分开
-将值加载到XML文档并根据需要提取
select case when 1 in ( 1, 2, 3 ) then xmltype ( cursor ( select 'abc' as "name 1", 'xyz' as "name 2" from dual ) ) else xmltype ( cursor ( select 'pqr' as "name 1" from dual ) ) end from dual; CASEWHEN1IN(1,2,3)THENXMLTYPE(CURSOR(SELECT'ABC'AS"NAME1",'XYZ'AS"NAME2"FROMDUAL))ELSEXMLTYPE(CURSOR(SELECT'PQR'AS"NAME1 ------------------------------------------------------------------------------------------------------------------------|
abc xyz 复制
等等。
但是这些都很麻烦。它通常更容易有两个案例表达式,第二个返回null在else:
select case when 1 in ( 1, 2, 3 ) then 'abc' else 'pqr' end "name 1", case when 1 in ( 1, 2, 3 ) then 'xyz' else null end "name 2" from dual; name 1 name 2 abc xyz复制
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。
评论
相关阅读
【专家有话说第五期】在不同年龄段,DBA应该怎样规划自己的职业发展?
墨天轮编辑部
1250次阅读
2025-03-13 11:40:53
Oracle RAC ASM 磁盘组满了,无法扩容怎么在线处理?
Lucifer三思而后行
756次阅读
2025-03-17 11:33:53
Oracle+Deepseek+Dify 实现数据库数据实时分析
bicewow
665次阅读
2025-03-06 09:41:49
【ORACLE】ORACLE19C在19.13版本前的一个严重BUG-24761824
DarkAthena
556次阅读
2025-03-04 14:33:31
Oracle避坑指南|同名表导出难题:如何精准排除指定用户下的表?
szrsu
506次阅读
2025-03-05 00:42:34
2月“墨力原创作者计划”获奖名单公布
墨天轮编辑部
447次阅读
2025-03-13 14:38:19
Ogg23ai高手必看-MySQL Innodb Cluster跟oracle的亲密接触
曹海峰
441次阅读
2025-03-04 21:56:13
【ORACLE】char类型和sql优化器发生的“错误”反应
DarkAthena
401次阅读
2025-03-04 23:05:01
什么,oracle 主机用户被删了?原来是虚惊一场!
Lucifer三思而后行
398次阅读
2025-03-03 21:12:09
Oracle 如何修改 db_unique_name?强迫症福音!
Lucifer三思而后行
336次阅读
2025-03-12 21:27:56