一、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%'SELECTID,NO AS "薪资",DECODE (SIGN (NO - 5000),1,'高薪',0,'高薪' ,- 1,DECODE (SIGN (NO - 3000), 1,'中薪',0,'中薪',- 1,'低薪'))
FROMSYS_USER
WHERElogin_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%'SELECTDECODE (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
FROMSYS_USER
WHERElogin_name LIKE 'test%'SELECTSUM (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
FROMSYS_USER
WHERElogin_name LIKE 'test%'SELECTDECODE (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
FROMSYS_USER
WHERElogin_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  

oracle中decode函数的使用相关推荐

  1. oracle 的wecate函数,1.Oracle中decode()函数用法

    1.Oracle中decode函数用法 含义解释: decode(条件,值1,返回值1,值2,返回值2,...值n,返回值n,缺省值) 该函数的含义如下: IF 条件=值1 THEN RETURN(翻 ...

  2. oracle+decode函数用法,oracle中decode函数用法

    oracle中decode函数用法以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! DECODE函数相当于一条件语句(IF ...

  3. oracle 中decode函数

    Oracle 中 decode 函数用法 含义解释: decode(条件,值1,返回值1,值2,返回值2,-值n,返回值n,缺省值) 该函数的含义如下: IF 条件=值1 THEN RETURN(翻译 ...

  4. Oracle中Decode()函数使用技巧

    DECODE函数是ORACLE PL/SQL是功能强大的函数之一,目前还只有ORACLE公司的SQL提供了此函数,其他数据库厂商的SQL实现还没有此功能.DECODE有什么用途 呢? 先构造一个例子, ...

  5. linux decode函数,Oracle 中 decode 函数用法

    Decode函数与一系列嵌套的 IF-THEN-ELSE语句相似.base_exp与compare1,compare2等等依次进行比较.如果base_exp和 第i 个compare项匹配,就返回第i ...

  6. Oracle 中 decode 函数用法

    转载自:http://www.cnblogs.com/vinsonLu/p/3512526.html 含义解释: decode(条件,值1,返回值1,值2,返回值2,...值n,返回值n,缺省值) 该 ...

  7. oracle decode别名,Oracle中decode函数用法 VelHong

    DECODE函数与一系列嵌套的 IF-THEN-ELSE语句相似.base_exp与compare1,compare2等等依次进行比较.如果base_exp和 第i 个compare项匹配,就返回第i ...

  8. Oracle中decode函数用法解析以及常用场景

    1.decode函数的两种形式 第一种形式 含义解释: decode(条件,值1,返回值1,值2,返回值2,-值n,返回值n,缺省值) 该函数的含义如下: IF 条件=值1 THENRETURN(翻译 ...

  9. oracle decode嵌套,Oracle 中 Decode函数用法 | YuXi

    含义解释: decode(条件,值1,返回值1,值2,返回值2,...值n,返回值n,缺省值) 该函数的含义如下: IF 条件=值1 THEN RETURN(翻译值1) ELSIF 条件=值2 THE ...

最新文章

  1. 使用pytorch创建神经网络并解决线性拟合和分类问题
  2. Windows下安装 openpyxl
  3. Conan and Agasa play a Card Game codeforce
  4. c语言指针实验报告总结,c语言指针实验报告
  5. Java开发环境的搭建(JDK和Eclipse的安装)
  6. 软件工程综合实践专题第三次个人博客作业
  7. Thinkphp5.0 多图上传名称重复BUG
  8. 计算机组成原理综合题,2013计算机组成原理复习题.doc
  9. 鸡兔同笼问题新解与Python实现
  10. 【LeetCode】【数组】题号:485,最大连续1的个数
  11. AutoCad 二次开发(一) 开发环境搭建
  12. python音乐推荐系统的设计与实现_基于协同过滤的音乐推荐系统
  13. 【Redis使用规范】
  14. [从零开始学习FPGA编程-26]:进阶篇 - 基本组合电路-数据选择器(Verilog语言)
  15. hdu 5857 Median(模拟)
  16. Contrastive Learning
  17. 工业机械设备设计与艺术设计
  18. python回调廖雪蜂_Python 廖雪峰教程《三》
  19. 国内各大互联网公司Java工程师笔经面经
  20. FLASHBACK QUERY(VERSION;TBLE;TRANSACTION)

热门文章

  1. 慕课网python就业_python全栈开发慕课网
  2. CPU核心数和线程数的关系 *
  3. BIOS dmi 信息获取
  4. 【精】设计师完全自学指南
  5. Sql增加,删除,修改列及修改约束
  6. java忍者_Java字节码忍者禁术
  7. centos7无线网络设置
  8. 《功夫熊猫》经典台词 从来没有什么意外
  9. LeetCode力扣刷题——千奇百怪的排序算法
  10. 如何在Windows server 2012配置Web服务器