朱利IT博客首页 | 设计模式 | 数据库 | 框架开发| 程序优化 | 控件学习 | 心得体会 | 给我留言

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

posted @ 2011-08-15 16:27  木子朱  阅读(336)  评论(0编辑  收藏  举报

朱利IT博客首页 | 设计模式 | 数据库 | 框架开发| WPF| WCF| IBatisNet| 程序优化 | 控件学习 | 心得体会 | 给我留言