服务器之家

服务器之家 > 正文

Oracle进阶DECODE函数使用详解

时间:2022-01-20 20:01     来源/作者:sdut菜鸟

DECODE含义

decode(条件,值1,返回值1,值2,返回值2,…值n,返回值n,缺省值)

这个是decode的表达式,具体的含义解释为:

IF 条件=值1 THEN
    RETURN(翻译值1)
ELSIF 条件=值2 THEN
    RETURN(翻译值2)
    ......
ELSIF 条件=值n THEN
    RETURN(翻译值n)
ELSE
    RETURN(缺省值)
END IF

DECODE的用法

这里主要说的就是decode的用法,在很多时候这个函数还是很有用的。

1.翻译值

数据截图:

Oracle进阶DECODE函数使用详解

需求:查询出的数据,1表示男生,2表示女生

select t.id,
       t.name,
       t.age,
       decode(t.sex, "1", "男生", "2", "女生", "其他") as sex
  from STUDENT2 t

结果:

Oracle进阶DECODE函数使用详解

2.decode比较大小

说明:sign(value)函数会根据value的值为0,正数,负数,分别返回0,1,-1

数据:

Oracle进阶DECODE函数使用详解

需求:年龄在20以上的显示20以上,20以下的显示20以下,20的显示正好20

select t.id,
       t.name,
       t.age,
       decode(sign(t.age - 20),
              1,
              "20以上",
              -1,
              "20以下",
              0,
              "正好20",
              "未知") as sex
  from STUDENT2 t

结果:

Oracle进阶DECODE函数使用详解

3.decode分段

数据暂无

需求:工资大于5000为高薪,工资介于3000到5000为中等,工资小于3000为底薪

select name,
       sal,
       decode(sign(sal - 5000),
              1,
              "高薪",
              0,
              "高薪",
              -1,
              decode(sign(sal - 3000), 1, "中等", 0, "中等", -1, "低薪")) as salname
  from person;

结果暂无

4.搜索字符串

数据:

Oracle进阶DECODE函数使用详解

需求:找到含有三的姓名

select t.id,
       decode(instr(t.name, "三"), 0, "姓名不含有三", "姓名含有三") as name,
       t.age,
       t.sex
  from STUDENT2 t

结果:

Oracle进阶DECODE函数使用详解

5.判断是否为空

数据:

Oracle进阶DECODE函数使用详解

需求:性别为空显示“暂无数据”,不为空原样输出

select t.id,
       t.name,
       t.age,
       decode(t.sex,NULL,"暂无数据",t.sex) as sex
  from STUDENT2 t

结果:

Oracle进阶DECODE函数使用详解

总结:decode在书写sql的时候还是挺有用的,常用的应该是1和5了吧(我猜的,因为我就是经常用这两种)

到此这篇关于Oracle进阶DECODE函数使用详解的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:https://blog.csdn.net/sdut406/article/details/82795585

标签:

相关文章

热门资讯

蜘蛛侠3英雄无归3正片免费播放 蜘蛛侠3在线观看免费高清完整
蜘蛛侠3英雄无归3正片免费播放 蜘蛛侠3在线观看免费高清完整 2021-08-24
yue是什么意思 网络流行语yue了是什么梗
yue是什么意思 网络流行语yue了是什么梗 2020-10-11
背刺什么意思 网络词语背刺是什么梗
背刺什么意思 网络词语背刺是什么梗 2020-05-22
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
2021年耽改剧名单 2021要播出的59部耽改剧列表
2021年耽改剧名单 2021要播出的59部耽改剧列表 2021-03-05
返回顶部