加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

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

发布时间:2020-12-12 16:31:20 所属栏目:MsSql教程 来源:网络整理
导读:我想选择*,而不必输出所有单独的列,但是我也想包括一个带有case语句的自定义列.我试过以下: select *,(case when PRI_VAL = 1 then 'High' when PRI_VAL = 2 then 'Med' when PRI_VAL = 3 then 'Low' end) as PRIORITYfrom MYTABLE; 但是这是抱怨的 ORA-0092
我想选择*,而不必输出所有单独的列,但是我也想包括一个带有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版本,不能确定其他数据库.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读