如何选择所有列,以及oracle 11g中CASE句子的结果?
技术问答
219 人阅读
|
0 人回复
|
2023-09-14
|
我想选择*,不需要输入所有单独的列,但我也想case句子包括一个自定义列。我尝试了以下方法:4 i% Z: W3 ]6 t4 _' ?; Z
select *,(case when PRI_VAL = 1 then 'High when PRI_VAL = 2 then 'Med when PRI_VAL = 3 then 'Low end) as PRIORITYfrom MYTABLE;但它在抱怨, t# ?& N) T2 Q3 S: a: Y' A4 F
ORA-00923: FROM keyword not found where expected + H# G% ]2 {* |' [0 h$ {# o/ n
解决方案:
$ ~0 K# _. A5 x& z 为mytable添加别名,如下所示:
/ h9 {# j" S% f! F( bselect t.*,(case when PRI_VAL = 1 then 'High when PRI_VAL = 2 then 'Med when PRI_VAL = 3 then 'Low end) as PRIORITYfrom MYTABLE t;这不依赖于任何特定的东西Oracle其他数据库也不确定版本。 |
|
|
|
|
|