Oracle的DECODE函数含义是什么,怎么使用
导读:这篇文章主要介绍了title,小编觉得挺不错的,现在分享给大家,也给大家做个参考,希望大家通过这篇文章可以有所收获。 DECODE含义 decode(条件,值1,返回值1,值2,返回值2,…值n,返回值n,缺省值 这个是dec...
这篇文章主要介绍了title,小编觉得挺不错的,现在分享给大家,也给大家做个参考,希望大家通过这篇文章可以有所收获。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.翻译值
数据截图:
需求:查询出的数据,1表示男生,2表示女生
select t.id, t.name, t.age, decode(t.sex, '1', '男生', '2', '女生', '其他') as sex from 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 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函数含义是什么,怎么使用”的相关知识,感谢各位的阅读,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注网络,小编每天都会为大家更新不同的知识。
声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!
若转载请注明出处: Oracle的DECODE函数含义是什么,怎么使用
本文地址: https://pptw.com/jishu/650327.html