SQL语句中的case when,decode的用法

以下面的表为例:
在这里插入图片描述
case when 将人物战斗力筛选成不同的级别:
用法:case when 字段 = '值1' then '结果1' when 字段 = '值2' then '结果2' else '结果3' end

实例:

select name,fightnum,skill, (case when fightnum = 20000 then '神级' 
                            when fightnum = 5000 then '影级'
                            else '战五渣' end)  as "战斗力分级"  
from huoying;

查询结果:
在这里插入图片描述
decode的用法:

(1)当使用decode函数判定某个字段,如果有多个值需要进行对比。用法decode(字段,值1,结果1,值2,结果2,值3,结果3),如果字段==值1,select返回结果1.如果字段=值2,返回结果2,以此类推。具体应用如下,

select name,decode(fightnum,'20000','神级','5000','影级','200','战五渣') as "级别" from huoying;

查询结果:
在这里插入图片描述
(2)当decode函数判定的函数只需要同一个值进行对比,用法decode(字段,需要对比的值,结果1,结果2),如果字段==需要对比的值,select返回结果1,否则返回结果2。具体应用如下:

select name,decode(skill,'绝对防御','是我爱罗','不是我爱罗') from huoying;

查询结果:
在这里插入图片描述

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值