mysql:对结果字段进行判断的函数
一、case when 函数
语法1:
CASE fieldname
WHEN value1 THEN result1
WHEN value2 THEN result2
WHEN value3 THEN result3
……
ELSE defaultresult
END
实例1:
SELECT
`id` '用户ID',
`name` '用户名称',
(
CASE `state`
WHEN 1 THEN '正常'
WHEN 2 THEN '不正常'
ELSE NULL
END
) '用户状态'
FROM
`user`
结果1:
语法2:
CASE
WHEN condition1 THEN result1
WHEN condition2 THEN result2
WHEN condition3 THEN result3
……
ELSE defaultresult
END
实例2:
SELECT
`id` '用户ID',
`name` '用户名称',
(
CASE
WHEN `state`=1 THEN '正常'
WHEN `state`=2 THEN '不正常'
ELSE NULL
END
) '用户状态'
FROM
`user`
结果2
二、if函数
case when 函数处理复杂逻辑判断比较常用,如果只是处理一次判断,更简单的方式是IF函数
语法:
IF(condition,result1,result2)
实例:
SELECT
`id` '用户ID',
`name` '用户名称',
IF(state=1,'正常','不正常') '用户状态'
FROM
`user`
结果:
三、elt函数
语法:
ELT(condition,result1,result2,result3,...)
注意:condition的值必须是顺序1、2、3、...才会对应结果result1、result2、result3、...
实例:
SELECT
`id` '用户ID',
`name` '用户名称',
`type`,
ELT(type,'普通员工','中层员工','高层员工') '用户类型'
FROM
`user`;
(转载不好意思原文地址忘了,如有侵权 请联系我 谢谢)