case在oracle中重新给指定字段赋值的一种用法
一、创建数据表
create table t(
id integer,
name varchar2(50)
)
二、添加数据
insert into t values(1,'zhao')
insert into t values(2,'qian')
insert into t values(3,'sun')
insert into t values(4,'li')
三、case用法:重新给指定字段赋值
例题1:
select t.Name,
(case t.id--此处可以省略括号,改变id为name
when 1 then 'zhao'
when 2 then 'qian'
when 3 then 'sun'
else 'li'
end) --注意不要丢掉end关键字哦
from T t
扩展:重新给指定字段赋值另一种方法:decode()的用法
select name, decode(id,1,'zhao',2,'qian',3,'sun','li') from T
例题2:
select name,
case
when id<=2 then 0
when id=3 then 1
else 2
end "targer" --定义别名,此处为双引号哦
from T