微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

sql – 如何选择所有列,加上oracle 11g中的CASE语句的结果?

我想选择*,而不必输出所有单独的列,但是我也想包括一个带有case语句的自定义列.我试过以下:
select *,(case when PRI_VAL = 1 then 'High'
                when PRI_VAL = 2 then 'Med'
                when PRI_VAL = 3 then 'Low'
          end) as PRIORITY
from MYTABLE;

但是这是抱怨的

ORA-00923: FROM keyword not found where expected

解决方法

为mytable添加一个别名,如下所示:
select t.*,(case when PRI_VAL = 1 then 'High'
                when PRI_VAL = 2 then 'Med'
                when PRI_VAL = 3 then 'Low'
          end) as PRIORITY
from MYTABLE t;

这不依赖于任何特定的Oracle版本,不能确定其他数据库.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐