软件下载

oracle中decode函数的用法(oracle数据库decode用法分享)

软件下载 投稿 2022-06-28 15:50:07 浏览

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用法

 

打开UC浏览器 查看更多精彩图片

打开百度APP,查看更多高清图片

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

select t.id,

t.name,

t.age,

decode(t.sex, '1', '男生', '2', '女生', '其他') as sex

from STUDENT2 t

结果:

oracle 函数decode用法

 

打开UC浏览器 查看更多精彩图片


2.decode比较大小

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

数据:

oracle 函数decode用法

 

打开UC浏览器 查看更多精彩图片

需求:年龄在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用法

 

打开UC浏览器 查看更多精彩图片


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用法

 

打开UC浏览器 查看更多精彩图片

需求:找到含有三的姓名

select t.id,

decode(instr(t.name, '三'), 0, '姓名不含有三', '姓名含有三') as name,

t.age,

t.sex

from STUDENT2 t

结果:

oracle 函数decode用法

 

打开UC浏览器 查看更多精彩图片


5.判断是否为空

数据:

oracle 函数decode用法

 

打开UC浏览器 查看更多精彩图片

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

select t.id,

t.name,

t.age,

decode(t.sex,NULL,'暂无数据',t.sex) as sex

from STUDENT2 t

结果:

oracle 函数decode用法

 

打开UC浏览器 查看更多精彩图片

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

「真诚赞赏,手留余香」

求资源网

真诚赞赏,手留余香

使用微信扫描二维码完成支付

继续浏览有关编程的文章
发表评论
留言与评论(共有 0 条评论)
   
验证码:
版权声明

求资源网所发布的一切破解补丁,软件,以及其他分析文章仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途。
否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。如有侵权请邮件与我们联系处理。