温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

oracle 菜鸟学习之 decode中if-then-else逻辑

发布时间:2020-06-09 11:10:01 来源:网络 阅读:1511 作者:运维少年 栏目:关系型数据库

oracle 菜鸟学习之 decode中if-then-else逻辑

decode类似于if - then - else

语法:
decode(values,if1,then1,if2,then2,...else)

values 代表某个表的任何类型的任意列或者一个通过计算所得的任何结果,当每个value值被测试,如果value的值为if1,decode函数的结果为then1,如果都不符合,那么就返回else
这里的ifthenelse都可以是函数或计算表达式。

例子

create table student(id number,name varchar2(4),sex number);
insert into student values(1,'A',1);
insert into student values(2,'B',2);
insert into student values(3,'C',1);

SQL> select * from student;

    ID NAME            SEX
---------- ------------ ----------
     1 A             1
     2 B             2
     3 C             1

SQL> 

问题:sex列,1显示为nan2显示为nv

SQL> select id,name,decode(sex,1,'nan','nv') from student;

    ID NAME     DECODE(SE
---------- ------------ ---------
     1 A        nan
     2 B        nv
     3 C        nan

SQL> 
sex -- values
1 -- if1
nan -- then1
nv -- else

实验

创建表:

create table sales(month number(3),sales_tv number(4),sales_computer number(4));
insert into sales values(01,10,18);
insert into sales values(02,28,20);
insert into sales values(03,36,33);

month:月份 sales_tv:电视机的销售量 sales_computer:计算机的销售量

问题:
选出每个月月份最多销售量,使用函数sign.
sign函数可以判断参数是正或负,正返回1,负返回-1,0返回0

SQL> select month,decode(sign(SALES_TV - SALES_COMPUTER),1,SALES_TV,0,SALES_TV,-1,SALES_COMPUTER) as max from sales;

     MONTH    MAX
---------- ----------
     1     18
     2     28
     3     36

SQL> 

原创:www.arppinging.com

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI