阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Oracle decode函数

215次阅读
没有评论

共计 2999 个字符,预计需要花费 8 分钟才能阅读完成。

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 专题页面 https://www.linuxidc.com/topicnews.aspx?tid=12

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-22发表,共计2999字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中