• 售前

  • 售后

热门帖子
入门百科

Oracle进阶DECODE函数使用详解

[复制链接]
A01祥天科技 显示全部楼层 发表于 2022-1-7 22:53:14 |阅读模式 打印 上一主题 下一主题
DECODE含义
  1. decode(条件,值1,返回值1,值2,返回值2,…值n,返回值n,缺省值)
复制代码
这个是decode的表达式,具体的含义解释为:
  1. IF 条件=值1 THEN
  2.     RETURN(翻译值1)
  3. ELSIF 条件=值2 THEN
  4.     RETURN(翻译值2)
  5.     ......
  6. ELSIF 条件=值n THEN
  7.     RETURN(翻译值n)
  8. ELSE
  9.     RETURN(缺省值)
  10. END IF
复制代码
DECODE的用法

这里重要说的就是decode的用法,在很多时候这个函数还是很有用的。
1.翻译值

数据截图:

需求:查询出的数据,1表示男生,2表示女生
  1. select t.id,
  2.        t.name,
  3.        t.age,
  4.        decode(t.sex, '1', '男生', '2', '女生', '其他') as sex
  5.   from STUDENT2 t
复制代码
结果:

2.decode比较巨细

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

需求:年龄在20以上的显示20以上,20以下的显示20以下,20的显示正好20
  1. select t.id,
  2.        t.name,
  3.        t.age,
  4.        decode(sign(t.age - 20),
  5.               1,
  6.               '20以上',
  7.               -1,
  8.               '20以下',
  9.               0,
  10.               '正好20',
  11.               '未知') as sex
  12.   from STUDENT2 t
复制代码
结果:

3.decode分段

数据暂无
需求:工资大于5000为高薪,工资介于3000到5000为中等,工资小于3000为底薪
  1. select name,
  2.        sal,
  3.        decode(sign(sal - 5000),
  4.               1,
  5.               '高薪',
  6.               0,
  7.               '高薪',
  8.               -1,
  9.               decode(sign(sal - 3000), 1, '中等', 0, '中等', -1, '低薪')) as salname
  10.   from person;
复制代码
结果暂无
4.搜刮字符串

数据:

需求:找到含有三的姓名
  1. select t.id,
  2.        decode(instr(t.name, '三'), 0, '姓名不含有三', '姓名含有三') as name,
  3.        t.age,
  4.        t.sex
  5.   from STUDENT2 t
复制代码
结果:

5.判定是否为空

数据:

需求:性别为空显示“暂无数据”,不为空原样输出
  1. select t.id,
  2.        t.name,
  3.        t.age,
  4.        decode(t.sex,NULL,'暂无数据',t.sex) as sex
  5.   from STUDENT2 t
复制代码
结果:

总结:decode在书写sql的时候还是挺有用的,常用的应该是1和5了吧(我猜的,因为我就是经常用这两种)
到此这篇关于Oracle进阶DECODE函数使用详解的文章就先容到这了。渴望对大家的学习有所资助,也渴望大家多多支持草根技术分享。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x

帖子地址: 

回复

使用道具 举报

分享
推广
火星云矿 | 预约S19Pro,享500抵1000!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

草根技术分享(草根吧)是全球知名中文IT技术交流平台,创建于2021年,包含原创博客、精品问答、职业培训、技术社区、资源下载等产品服务,提供原创、优质、完整内容的专业IT技术开发社区。
  • 官方手机版

  • 微信公众号

  • 商务合作