CASE表达式在mysql中用于实现条件逻辑,支持简单CASE和搜索CASE两种形式,可在select、WHERE、ORDER BY等子句中使用;常用于返回自定义值、控制查询逻辑、结合聚合函数进行分组统计,提升SQL表达能力与实用性。

在mysql中,CASE表达式是一种强大的工具,用于在查询中实现条件逻辑。它类似于编程语言中的 if-else 或 switch 语句,可以根据不同的条件返回不同的值。CASE 表达式可以在 SELECT、WHERE、ORDER BY 等子句中使用,非常灵活。
基本语法:简单 CASE 与搜索 CASE
MySQL 支持两种形式的 CASE 表达式:
1. 简单 CASE:将一个表达式与多个可能值进行比较
CASE value
WHEN value1 THEN result1
WHEN value2 THEN result2
ELSE default_result
END
2. 搜索 CASE:基于布尔表达式进行判断
CASE
WHEN condition1 THEN result1
WHEN condition2 THEN result2
ELSE default_result
END
在 SELECT 中使用 CASE 返回自定义值
最常见的用途是在查询结果中根据字段值返回描述性文本或分类。
例如,假设有一个订单表 orders,其中 status 字段为数字(0:待处理, 1:已发货, 2:已完成),我们想显示中文状态:
CASE status
WHEN 0 THEN ‘待处理’
WHEN 1 THEN ‘已发货’
WHEN 2 THEN ‘已完成’
ELSE ‘未知状态’
END AS status_label
这样可以在结果中看到可读性强的状态名称,而不是数字。
在 WHERE 和 ORDER BY 中使用条件逻辑
CASE 不仅可用于输出字段,也能用于控制查询逻辑。
比如按优先级排序:希望已完成订单排在前面,其次是已发货,最后是待处理:
ORDER BY
CASE status
WHEN 2 THEN 1
WHEN 1 THEN 2
WHEN 0 THEN 3
END
又如,在 WHERE 子句中动态判断(注意:CASE 在 WHERE 中使用较少,通常用 OR/AND 更清晰):
查找高价值客户或特定地区客户:
WHERE
CASE
WHEN region = ‘北京’ THEN TRUE
WHEN total_amount > 10000 THEN TRUE
ELSE FALSE
END
结合聚合函数实现分组统计
CASE 常与 SUM、count 配合,在一条查询中实现多维度统计。
例如统计每个部门男女员工数量:
SELECT
dept,
SUM(CASE WHEN gender = ‘M’ THEN 1 ELSE 0 END) AS male_count,
SUM(CASE WHEN gender = ‘F’ THEN 1 ELSE 0 END) AS female_count
FROM employees GROUP BY dept
这种写法避免了多次查询,效率更高。
基本上就这些。CASE 表达式让 SQL 具备了基础的条件判断能力,合理使用能显著提升查询的表达力和实用性。注意确保所有分支覆盖完整,建议始终包含 ELSE 子句以防意外空值。


