Hi,大家好,我是编程小6,很荣幸遇见你,我把这些年在开发过程中遇到的问题或想法写出来,今天说一说
oracle数据库中decode函数的作用_csstransform属性,希望能够帮助你!!!。
if(条件=值1){ 返回值1 }else if(条件=值2){ 返回值2 } . . . . . . else{ 缺省值/默认值 }
(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%'
(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%'
关于第二步中的根据一条数据中的某一列显示该数据中的另一列数据,这个应该是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, 'test',NO,0) test, 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,'test',NO,0)) test, 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, 'test',NAME,0) test, DECODE (login_name, 'testing', NAME, 0) testing FROM SYS_USER WHERE login_name LIKE 'test%'
(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”开始出现的位置
PS:图中涉及到的SQL,可复制后自行修改
SELECT login_name AS "账户",INSTR(login_name, 'test') AS "返回值",DECODE(INSTR(login_name, 'test'),0,'不含有test','含有test') AS "查询结果" FROM SYS_USER
今天的分享到此就结束了,感谢您的阅读,如果确实帮到您,您可以动动手指转发给其他人。
上一篇
已是最后文章
下一篇
已是最新文章