CASE语句是MySQL实现条件逻辑的核心工具,分简单CASE(值匹配)和搜索CASE(布尔条件),用于SELECT动态分类、UPDATE条件赋值、WHERE动态过滤,需注意类型一致、顺序匹配及索引性能。

CASE 语句是 MySQL 中实现条件逻辑的核心工具,常用于 SELECT、UPDATE、WHERE 等语句中,根据表达式或条件返回不同结果,类似编程语言中的 if-else 或 switch。
基本语法:两种写法要分清
MySQL 支持两种 CASE 格式,用途和写法不同,容易混淆,需注意区分:
-
简单 CASE(基于值匹配):适用于判断某个字段/表达式是否等于若干固定值。
CASE column_name
WHEN value1 THEN result1
WHEN value2 THEN result2
ELSE default_result
END -
搜索 CASE(基于布尔条件):更灵活,支持任意表达式和比较运算(如 >, LIKE, IS NULL 等)。
CASE
WHEN condition1 THEN result1
WHEN condition2 THEN result2
ELSE default_result
END
在 SELECT 中动态生成新字段
这是最常见用法,用于按规则分类、转义、脱敏或计算标签。例如将用户年龄分组:
- 使用搜索 CASE(推荐,逻辑清晰):
SELECT name, age,
CASE
WHEN age WHEN age BETWEEN 18 AND 60 THEN '成年人'
ELSE '老年人'
END AS age_group
FROM users; - 注意:CASE 表达式在 SELECT 中可直接起别名,无需额外包裹;ELSE 子句建议保留,避免 NULL 值干扰展示。
在 UPDATE 和 WHERE 中控制执行逻辑
CASE 不仅能“查”,还能“改”和“筛”:
-
UPDATE 中条件赋值:一行语句更新多个不同值。
UPDATE orders SET status =
CASE
WHEN pay_time IS NULL THEN '待支付'
WHEN delivery_time IS NULL THEN '已付款'
ELSE '已完成'
END; -
WHERE 中构造动态条件:配合函数或变量实现灵活过滤(慎用,可能影响索引)。
SELECT * FROM products
WHERE price > CASE WHEN @discount_mode = 'vip' THEN 50 ELSE 100 END;
注意事项和常见坑
- CASE 表达式必须有返回值类型一致性:所有 THEN 和 ELSE 的结果应为兼容类型(如全为字符串或全为数字),否则 MySQL 可能隐式转换或报错。
- 条件判断顺序重要:CASE 按从上到下匹配,第一个为 TRUE 的 WHEN 分支即生效,后续不再执行——所以范围判断要从小到大或加边界限制(如用 BETWEEN 或 AND 连接)。
- 不能单独执行 CASE:它不是独立语句,必须嵌入在 SELECT、UPDATE、INSERT … SELECT、存储过程等上下文中使用。
- 性能提示:在 WHERE 或 ON 中大量使用复杂 CASE 可能导致无法使用索引,建议优先考虑函数索引或冗余字段+触发器预计算。










