在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
DECODE含义
这个是decode的表达式,具体的含义解释为: IF 条件=值1 THEN RETURN(翻译值1) ELSIF 条件=值2 THEN RETURN(翻译值2) ...... ELSIF 条件=值n THEN RETURN(翻译值n) ELSE RETURN(缺省值) END IF DECODE的用法这里主要说的就是decode的用法,在很多时候这个函数还是很有用的。 1.翻译值数据截图: 需求:查询出的数据,1表示男生,2表示女生 select t.id, t.name, t.age, decode(t.sex, '1', '男生', '2', '女生', '其他') as sex from STUDENT2 t 结果: 2.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 结果: 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.搜索字符串数据: 需求:找到含有三的姓名 select t.id, decode(instr(t.name, '三'), 0, '姓名不含有三', '姓名含有三') as name, t.age, t.sex from STUDENT2 t 结果: 5.判断是否为空数据: 需求:性别为空显示“暂无数据”,不为空原样输出 select t.id, t.name, t.age, decode(t.sex,NULL,'暂无数据',t.sex) as sex from STUDENT2 t 结果: 总结:decode在书写sql的时候还是挺有用的,常用的应该是1和5了吧(我猜的,因为我就是经常用这两种) 到此这篇关于Oracle进阶DECODE函数使用详解的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持极客世界。 |
请发表评论