Oracle数据库之Oracle decode函数
小标 2018-08-20 来源 : 阅读 2983 评论 0

摘要:本文主要向大家介绍了Oracle数据库之Oracle decode函数,通过具体的内容向大家展现,希望对大家学习Oracle数据库有所帮助。

本文主要向大家介绍了Oracle数据库之Oracle decode函数,通过具体的内容向大家展现,希望对大家学习Oracle数据库有所帮助。

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表达式一样效果。    

本文由职坐标整理并发布,希望对同学们学习Oracle有所帮助,更多内容请关注职坐标数据库Oracle数据库频道!

本文由 @小标 发布于职坐标。未经许可,禁止转载。
喜欢 | 1 不喜欢 | 0
看完这篇文章有何感觉?已经有1人表态,100%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式AI+学习就业服务平台 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved