oracle中decode函数的使用
一、DECODE函数相当于if条件语句,它将输入的值与函数中的参数列比较,根据输入值返回一个对应值
1、语法:decode(条件,值1,返回值1,值2,返回值2,...值n,返回值n,缺省值)
2、说明:当“条件”等于“值1”的时候,显示“返回值1”,等于“值2”的时候,显示“返回值2”,依次类推,如果都不满足,则显示“缺省值”即默认值。
3、逻辑:类似于以下操作
if(条件=值1){
返回值1
}else if(条件=值2){
返回值2
}
.
.
.
.
.
.
else{
缺省值/默认值
}
4、举例
(1)先了解数据表结构:id是数据id,login_name是账号,为方便演示,此处做了查询条件的限制
(2)执行操作后的结果:当login_name的值是“test”的时候,输出“我是第一个”,当login_name的值是“mtest”的时候,输出“我是就是我”,当前面的情况都不满足时,输出“哈哈”
(3)需要注意的是,当decode函数中只有4个值的时候【decode(条件,值,返回值1,返回值2)】,就要考虑只是做了一种判断,即条件满足值时输出返回值1,否则输出返回值2
PS:图中涉及到的SQL,可复制后自行修改
select id,login_name AS "账号" FROM SYS_USER where login_name like '%test%'
select id,login_name AS "账号",DECODE(login_name,'test','我是第一个','mtest','我是就是我','哈哈') AS "输出内容" FROM SYS_USER where login_name like '%test%'
select id,login_name AS "账号",DECODE(login_name,'test','我是第一个','哈哈') AS "输出内容" FROM SYS_USER where login_name like '%test%'
二、与sign()函数结合使用
1、sign是一种计算机函数,语法为sign(值),当值大于0时返回1,小于0时返回-1,等于0时返回0
2、举例:id为数据的id,此处仅做参考作用,NO为编号
3、结合使用
(1)可以用来标记数据
(2)同样可以用来做分段函数,如当薪资大于等于5000的时候,分段为“高薪”;当薪资大于等于3000且小于5000时属于“中薪”;小于3000属于低
逻辑: 薪资与5千比较,返回-1表明小于5000,即往下执行-1对应的操作,反之大于等于5千,表示高薪;薪资与3000比较,返回-1则表示小于3000,即低薪,反之大于等于3千且小于5千属于中薪
示例:
说明: Ⅰ、sign(500-5000),返回-1,执行-1对应的操作,即decode(sign(500-3000) , 1,'中薪',0,'中薪',- 1,'低薪'),sign(500-3000)返回-1,即返回值为“低薪”
Ⅱ、sign(6000-5000),返回1,即返回值为“高薪”
Ⅲ 、sign(3500-5000),返回-1,执行-1对应的操作,即decode(sign(3500-3000) , 1,'中薪',0,'中薪',- 1,'低薪'),sign(3500-3000)返回1,即返回值为“中薪”
Ⅳ、sign(3200-5000),返回-1,执行-1对应的操作,即decode(sign(3200-3000) , 1,'中薪',0,'中薪',- 1,'低薪'),sign(3200-3000)返回1,即返回值为“中薪”
Ⅴ、sign(6000-5000),返回1,即返回值为“高薪”
Ⅵ、sign(4500-5000),返回-1,执行-1对应的操作,即decode(sign(4500-3000) , 1,'中薪',0,'中薪',- 1,'低薪'),sign(4500-3000)返回1,即返回值为“中薪”
PS:图中涉及到的SQL,可复制后自行修改
select id,NO AS "编号",sign(NO) AS "编号的返回值" FROM SYS_USER where login_name like '%test%'
select id,NO AS "编号",sign(NO) AS "编号的返回值",decode(sign(NO),-1,'编号为负数','0','编号为自然数0','编号是正数') AS "输出结果" FROM SYS_USER where login_name like '%test%'
SELECT
ID,
NO AS "薪资",
DECODE (
SIGN (NO - 5000),1,'高薪',0,'高薪' ,
- 1,DECODE (SIGN (NO - 3000), 1,'中薪',0,'中薪',- 1,'低薪')
)
FROM
SYS_USER
WHERE
login_name LIKE '%test%'
三、结合SUM()函数实现表或者视图中的列转行
需求:以账号为表头,显示对应的薪资数据
1、先看原数据:
2、利用decode函数实现根据账户名显示对应的薪资数据
3、利用sum求和函数,实现最终需求
关于第二步中的根据一条数据中的某一列显示该数据中的另一列数据,这个应该是decode算法的原因,具体没深研究,感兴趣的小伙伴儿可以自己研究
PS:图中涉及到的SQL,可复制后自行修改
select login_name AS "账号",NO AS "薪资" FROM SYS_USER where login_name like 'test%'
SELECT
DECODE (login_name, 'test', NO, 0) TEST,
DECODE (login_name, 'test01', NO, 0) test01,
DECODE (login_name, 'test1', NO, 0) test1,
DECODE (login_name, 'test123456789',NO,0) test123456789,
DECODE (login_name, 'testing', NO, 0) testing
FROM
SYS_USER
WHERE
login_name LIKE 'test%'
SELECT
SUM (DECODE (login_name, 'test', NO, 0)) TEST,
SUM (DECODE (login_name, 'test01', NO, 0)) test01,
SUM (DECODE (login_name, 'test1', NO, 0)) test1,
SUM (DECODE (login_name,'test123456789',NO,0)) test123456789,
SUM (DECODE (login_name, 'testing', NO, 0)) testing
FROM
SYS_USER
WHERE
login_name LIKE 'test%'
SELECT
DECODE (login_name, 'test', NAME, 0) TEST,
DECODE (login_name, 'test01',NAME, 0) test01,
DECODE (login_name, 'test1', NAME, 0) test1,
DECODE (login_name, 'test123456789',NAME,0) test123456789,
DECODE (login_name, 'testing', NAME, 0) testing
FROM
SYS_USER
WHERE
login_name LIKE 'test%'
四、结合instr()函数,实现字符的搜索并返回结果
1、先来了解下instr()函数:instr函数为字符查找函数,其功能是查找一个字符串在另一个字符串中首次出现的位置
(1)语法:instr( string1, string2, start_position,nth_appearance )
string1:源字符串,要在此字符串中查找。
string2:要在string1中查找的字符串 。
start_position:代表string1 的哪个位置开始查找,此参数可选,如果省略默认为1. 字符串索引从1开始。如果此参数为正,从左到右开始检索,如果此参数为负,从右到左检索,返回要查找的字符串在源字符串中的开始索引。
nth_appearance:代表要查找第几次出现的string2.,此参数可选,如果省略,默认为 1。如果为负数系统会报
注意:位置索引号从1开始。如果String2在String1中没有找到,instr函数返回0
(2)示例:
SELECT instr('syranmo','s') FROM dual; -- 返回 1
SELECT instr('syranmo','ra') FROM dual; -- 返回 3
SELECT instr('syran mo','at',1,2) FROM dual; -- 返回 0
select instr('helloworld','l') from dual; --返回结果:3 默认第一次出现“l”的位置
select instr('helloworld','lo') from dual; --返回结果:4 即:在“lo”中,“l”开始出现的位置
select instr('helloworld','wo') from dual; --返回结果:6 即“w”开始出现的位置
2、结合instr函数,实现需求
PS:图中涉及到的SQL,可复制后自行修改
SELECT login_name AS "账户",INSTR(login_name, 'test') AS "返回值",DECODE(INSTR(login_name, 'test'),0,'不含有test','含有test') AS "查询结果" FROM SYS_USER
更多推荐
所有评论(0)