在SQL查询的实际操作中,我们常常需要对查询结果中的字段值做条件判断,根据判断结果返回不同的内容,比如将数值型的成绩转换为等级描述,或者根据不同状态值显示对应的业务含义,这时候就可以使用CASE WHEN语句来实现条件分支逻辑。

CASE WHEN语句的基本语法
CASE WHEN语句是SQL中用于实现条件判断的结构,主要有两种常用的语法形式,分别适用于不同的使用场景。
第一种:简单CASE表达式
这种形式适合判断某个字段的值是否等于多个固定取值,语法结构如下:
CASE 待判断的字段
WHEN 值1 THEN 返回结果1
WHEN 值2 THEN 返回结果2
...
ELSE 默认返回结果
END
其中ELSE子句是可选的,如果不写,当所有WHEN条件都不满足时,会返回NULL值。
第二种:搜索CASE表达式
这种形式支持更复杂的条件判断,比如范围判断、多字段组合判断等,语法结构如下:
CASE
WHEN 条件1 THEN 返回结果1
WHEN 条件2 THEN 返回结果2
...
ELSE 默认返回结果
END
CASE WHEN的实际使用案例
单条件等值判断场景
假设我们有一张学生成绩表student_score,表结构如下:
| 字段名 | 类型 | 说明 |
|---|---|---|
| student_id | INT | 学生ID |
| score | INT | 考试分数 |
现在需要查询每个学生的分数,并额外返回对应的等级,规则是:分数大于等于90为优秀,80到89为良好,70到79为中等,60到69为及格,低于60为不及格。可以使用搜索CASE表达式实现:
SELECT
student_id,
score,
CASE
WHEN score >= 90 THEN '优秀'
WHEN score >= 80 THEN '良好'
WHEN score >= 70 THEN '中等'
WHEN score >= 60 THEN '及格'
ELSE '不及格'
END AS score_level
FROM student_score;
多字段组合判断场景
再假设有一张订单表order_info,包含order_status(订单状态:1待支付、2已支付、3已发货、4已完成)和pay_type(支付类型:1微信、2支付宝、3银行卡)两个字段,需要查询订单信息,并将状态和支付类型转换为中文描述,这时候可以使用简单CASE表达式:
SELECT
order_id,
CASE order_status
WHEN 1 THEN '待支付'
WHEN 2 THEN '已支付'
WHEN 3 THEN '已发货'
WHEN 4 THEN '已完成'
ELSE '未知状态'
END AS status_desc,
CASE pay_type
WHEN 1 THEN '微信支付'
WHEN 2 THEN '支付宝支付'
WHEN 3 THEN '银行卡支付'
ELSE '其他支付'
END AS pay_desc
FROM order_info;
使用CASE WHEN的注意事项
- CASE WHEN语句中的条件判断是有顺序的,会从上到下依次匹配,匹配到第一个满足条件的分支就会返回结果,后面的分支不会再执行,因此条件的顺序需要根据业务逻辑合理排列。
- CASE WHEN语句最终返回的结果类型需要保持一致,比如不能同时返回字符串和数值,否则可能会出现类型转换错误。
- CASE WHEN语句不仅可以用在SELECT子句中,还可以用在WHERE子句、ORDER BY子句等位置,比如根据条件排序:
SELECT * FROM product ORDER BY CASE WHEN category = '热门' THEN 1 WHEN category = '普通' THEN 2 ELSE 3 END;