20170920--mysql--case when

case when 的三种用法:


1. case 字段 when ,字段的具体值。

select a.*, 
case name
when '流浪' then '法师'
else '战士'
end as '类型'
FROM c_20170920 a



2. case when 字段,这个可以对字段进行取范围。

SELECT a.*,
CASE 
WHEN a.age BETWEEN 0 and 20 THEN '青年'
WHEN a.age BETWEEN 20 and 40 THEN '中年'
ELSE '非人类'
END AS '描述'
FROM
c_20170920 a



3. case when 字段1,字段2,可以对多个字段进行替换

SELECT a.*,
CASE 
WHEN a.age BETWEEN 20 and 80 THEN '青年'
WHEN a.name ='流浪' THEN '帅气'
END AS '描述'
FROM
c_20170920 a


这里需要注意的是,如果两个条件都针对一个字段的话,会显示第一个when的值。

比如下面:

SELECT a.*,
CASE 
WHEN a.age BETWEEN 0 and 20 THEN '青年'
WHEN a.name ='流浪' THEN '帅气'
END AS '描述'
FROM
c_20170920 a


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值