oracle用case计算分段函数,Oracle decode函数

decode函数在oracle sql查询语句中的使用非常广泛,也经常应用到pl/sql语句块中。

1,decode()函数语句的基本表达式是:

decode(expr1,expr2,expr3,[expr4])

这个表达式个人理解,可以称之为decode的比较运算,可以对比 nvl()函数和 coalesce()函数。可以作如下理解该表达式:

1,如果expr1 = expr2,decode函数返回expr3表达式的值;

2,如果expr1 != expr2,decode函数返回expr4表达式的值,如果expr4未指定,则返回null;

使用示例1:

select decode(1,-1,100,90),decode(-1,-1,100,90),decode(0,-1,100) from dual;

decode(1,-1,100,90) decode(-1,-1,100,90) decode(0,-1,100)

------------------- -------------------- -------------------

90           100

示例说明:第一个decode函数表达式中,1 != -1,所以返回90;第二个decode函数表达式中,-1 = -1,所以返回100,第三个decode函数表达式中,0 != -1,但是未指定第4个表达式的值,所以函数返回null值。

示例2,decode函数另类用法:比如我们要查询出emp表中,有奖金的员工和没有奖金员工的总数量

通常情况下,我们需要两个查询语句:

select count(*) from emp where comm is not null;

select count(*) from emp where comm is null;

但是使用decode函数,我们可以在一行查询中搞定:

select sum(decode(nvl(comm,1),1,1,0)) count_no_comm,sum(decode(nvl(comm,1),1,0,1)) conut_comm from emp;

count_no_comm conut_comm

------------- ----------

10 4

代码说明:借助于nvl() 函数来判定奖金comm是否为空,如果为空返回值为1,然后拿nvl的返回值和1进行比较,如果相等,返回1(说明comm为空),不等返回0(说明comm不为空); 最后sum对decode的返回结果进行加和,求出结果。

2,decode分段函数,是上述decode比较运算的一种变式,形式和case 表达式很相似,可以作为参考比较

语法结构:

decode(expr1,expr2,return_expr2, --如果expr1=expr2,返回return_expr2;

expr3,return_expr2, --如果expr1=expr3,返回return_expr3;

exprn,return_exprn, --如果expr1=expr2,返回return_exprn;

exprx) [new_expr] --如果expr1不再上述expr2-exprn之间,返回return_exprx; new_expr为别名

使用示例:根据部门id不同,对薪资进行相应的调整

1,我们先用case表达式实现:

select ename,deptno,sal,case deptno when 10 then sal * 1.1

when 20 then sal * 1.2

when 30 then sal * 1.3

else sal

end new_sal

from emp order by deptno,new_sal;

ename deptno sal new_sal

-------------------- ---------- ---------- ----------

miller 10 1800 1980

clark 10 2950 3245

king 10 5000 5500

smith 20 1300 1560

adams 20 1600 1920

ford 20 3000 3600

scott 20 3000 3600

jones 20 3475 4170

james 30 1450 1885

ward 30 1750 2275

martin 30 1750 2275

turner 30 2000 2600

allen 30 2100 2730

blake 30 3350 4355

2,使用decode函数实现

select ename,deptno,sal,decode(deptno,10,sal * 1.1,

20,sal * 1.2,

30,sal * 1.3,

sal) new_sal

from emp;

ename deptno sal new_sal

-------------------- ---------- ---------- ----------

scott 20 3000 3600

smith 20 1300 1560

allen 30 2100 2730

ward 30 1750 2275

jones 20 3475 4170

martin 30 1750 2275

blake 30 3350 4355

clark 10 2950 3245

king 10 5000 5500

turner 30 2000 2600

adams 20 1600 1920

james 30 1450 1885

ford 20 3000 3600

miller 10 1800 1980

在某些情况下,使用decode函数可以达到和case表达式一样效果。

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值