DECODE含义

decode(条件,值1,返回值1,值2,返回值2,…值n,返回值n,缺省值)
这个是decode的表达式,具体的含义解释为:

IF 条件=值1 THENRETURN(翻译值1)
ELSIF 条件=值2 THENRETURN(翻译值2)......
ELSIF 条件=值n THENRETURN(翻译值n)
ELSERETURN(缺省值)
END IF

DECODE的用法

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

1.翻译值

数据截图:

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

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

结果:

2.decode比较大小

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

需求:年龄在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 sexfrom STUDENT2 t

结果:

3.decode分段

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

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

结果暂无

4.搜索字符串

数据:

需求:找到含有三的姓名

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

结果:

5.判断是否为空

数据:

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

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

结果:

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

【ORACLE】Oracle提高篇之DECODE相关推荐

  1. oracle 语句提高查询效率的方法

    oracle 语句提高查询效率的方法 1:.. where column in(select * from ... where ...); 2:... where exists (select 'X' ...

  2. RHEL 5.4 安装Oracle 11gR2, 安装篇1...

    安装之前要对RH 5.4做一些系统准备,请参考准备篇: http://nvd11.blog.163.com/blog/static/2000183122012711057110/ 步骤1: copy ...

  3. oracle静默安装集群,静默安装Oracle数据库10g篇

    静默安装Oracle数据库10g篇 =========================================================================== 以下是在Li ...

  4. 学习Oracle这一篇就够了

    目录 第一章 数据库概述 1.1.数据库的好处 1.2.数据库的常见概念 1.3.数据库的存储特点 1.4.数据库的常见分类 1.5.SQL语言的分类 第二章 Oracle概述 2.1.Oracle的 ...

  5. [网络安全提高篇] 一一五.Powershell恶意代码检测 (3)Token关键词自动提取

    "网络安全提高班"新的100篇文章即将开启,包括Web渗透.内网渗透.靶场搭建.CVE复现.攻击溯源.实战及CTF总结,它将更加聚焦,更加深入,也是作者的慢慢成长史.换专业确实挺难 ...

  6. Maven提高篇系列之(三)——使用自己的Repository(Nexus)

    这是一个Maven提高篇的系列,包含有以下文章: Maven提高篇系列之(一)--多模块 vs 继承 Maven提高篇系列之(二)--配置Plugin到某个Phase(以Selenium集成测试为例) ...

  7. oracle -- Oracle初始化参数详解

    oracle -- Oracle初始化参数详解 Oracle数据库系统根据初始化参数文件init.ora中设置的参数来配置自身的启动,每个实例在启动之前,首先读取这些参数文件中设置的不同参数. Ora ...

  8. [网络安全提高篇] 一一九.恶意软件动态分析经典沙箱Cape的安装和基础用法详解

    终于忙完初稿,开心地写一篇博客. "网络安全提高班"新的100篇文章即将开启,包括Web渗透.内网渗透.靶场搭建.CVE复现.攻击溯源.实战及CTF总结,它将更加聚焦,更加深入,也 ...

  9. oracle里有limit怎么用,[ORACLE]ORACLE 实现mysql中的limit 功能

    [ORACLE]ORACLE 实现mysql中的limit 功能 项目从mysql迁移到ORACLE中遇到移植问题,mysql中支持limit 而ORACLE say no . 解决方法 利用ORAC ...

最新文章

  1. iphone 使用popViewController如何避免内存泄露
  2. docker for ubuntu安装
  3. Mapgis6.7 林相图自动注记 .
  4. arm linux 加载.a,如何将libc.a链接到arm-linux中的共享库中使用arm-none-linux-gnueabi-gcc...
  5. java 工厂模式的写法_java简单工厂模式是什么
  6. web应用程序和Web网站区别
  7. C#正则的委托和lambda表达式用法
  8. 射频测试系统软件,新的~~蓝牙5.0射频测试系统
  9. 常见设计模式的思考1
  10. vs快速添加引用解析的快捷键
  11. C#异步加载数据:BackgroundWorker的使用
  12. 为Springboot工作流版本myabaits的xml 建表
  13. ORACLE EBS常用表
  14. 无线耳机哪个品牌好一点?真无线蓝牙耳机推荐品牌
  15. 徐辉 北大计算机,徐辉的痛苦回忆_徐辉经历的那一段痛苦回忆
  16. iOS音频播放之AudioQueue(一):播放本地音乐
  17. MNN实践[C++版本]
  18. 【LeetCode】跳跃游戏Ⅰ~Ⅵ(我真的跳晕了@_@)
  19. 速方云怎么下载keep2share文件?
  20. 概率论小课堂:统计学是大数据方法的基础

热门文章

  1. 最大k乘积问题----动态规划
  2. MAC层与llc层的区别
  3. mybatis字符串拼接
  4. Android MVVM探究(一)
  5. 大学生读者让我帮找二分查找的bug
  6. python写我爱你_Python初体验之我爱你
  7. 修改浏览器名称和图标+下载网站的ico图标(绝对有效)
  8. 黑马 pink h5+css3+移动端前端
  9. 李泉老师《 优雅形体,美好气质》
  10. 为什么建议MySQL列属性尽量NOT NULL