金昌市网站建设_网站建设公司_HTML_seo优化
2025/12/29 21:31:05 网站建设 项目流程

SQL 中 CASE WHEN 用法全面详解

CASE WHEN是 SQL 中非常强大的条件判断表达式,类似于编程语言中的if-elseswitch语句。它可以根据条件返回不同的值,常用于数据转换、分组统计、动态排序等场景。

SQL 中有两种 CASE 语法:

1. 简单 CASE(类似 switch)
CASE表达式WHEN1THEN结果1WHEN2THEN结果2...ELSE默认结果END
2. 搜索 CASE(更常用,类似 if-elseif-else)
CASEWHEN条件1THEN结果1WHEN条件2THEN结果2...ELSE默认结果END

注意END是必须的!否则报错。ELSE可省略,省略时相当于ELSE NULL


一、基本用法示例

假设有表students

idnamescore
1张三85
2李四62
3王五95
4赵六45
5nullnull
示例1:根据分数划分等级(搜索 CASE,最常用)
SELECTname,score,CASEWHENscore>=90THEN'优秀'WHENscore>=80THEN'良好'WHENscore>=60THEN'及格'ELSE'不及格'ENDASgradeFROMstudents;

结果:

namescoregrade
张三85良好
李四62及格
王五95优秀
赵六45不及格
nullnull不及格(因为 NULL 不满足任何条件)
示例2:简单 CASE(匹配具体值)
SELECTname,score,CASEscoreWHEN100THEN'满分'WHEN0THEN'零分'ELSE'普通分数'ENDASremarkFROMstudents;
示例3:处理 NULL 值
SELECTname,CASEWHENscoreISNULLTHEN'未考试'WHENscore>=60THEN'通过'ELSE'未通过'ENDASstatusFROMstudents;
示例4:在 ORDER BY 中动态排序(超级实用!)
-- 优先让 score=100 的排最前,其余按 score 降序SELECTname,scoreFROMstudentsORDERBYCASEWHENscore=100THEN0ELSE1END,-- 100分排前面scoreDESC;
示例5:在 UPDATE 中使用(修改数据)
UPDATEstudentsSETgrade=CASEWHENscore>=90THEN'A'WHENscore>=80THEN'B'WHENscore>=60THEN'C'ELSE'F'END;
示例6:结合聚合函数统计(分组统计神器)
SELECTCASEWHENscore>=90THEN'优秀'WHENscore>=60THEN'及格'ELSE'不及格'ENDASlevel,COUNT(*)AScount,AVG(score)ASavg_scoreFROMstudentsGROUPBYCASEWHENscore>=90THEN'优秀'WHENscore>=60THEN'及格'ELSE'不及格'END;

结果示例:

levelcountavg_score
优秀195.0
良好185.0
及格162.0
不及格145.0
示例7:多条件组合(AND/OR)
CASEWHENscore>=90ANDnameLIKE'张%'THEN'优秀且姓张'WHENscore>=80ORscoreISNULLTHEN'良好或未考'ELSE'其他'END
示例8:嵌套 CASE(不推荐过多嵌套,可读性差)
CASEWHENscoreISNULLTHEN'未考'ELSECASEWHENscore>=90THEN'优秀'ELSE'非优秀'ENDEND

二、常见注意事项

注意点说明
类型一致所有THENELSE的结果类型必须一致(都是字符串或数字)
NULL 判断IS NULL/IS NOT NULL,不能用= NULL
条件执行顺序从上到下,满足第一个条件就返回,后面的不再判断
可在 SELECT/WHERE/GROUP BY/ORDER BY/HAVING 中使用全方位可用
MySQL 支持在 WHERE 中直接用 CASE但建议逻辑放 SELECT 中更清晰
性能过多复杂 CASE 可能影响性能,必要时考虑建视图或存储过程

三、实际应用场景总结

场景推荐用法
数据清洗/转换将代码转为可读文字(如 status 1→’启用’)
动态分组统计按条件分组 COUNT/SUM/AVG
自定义排序规则ORDER BY CASE …
报表字段生成生成“等级”“是否达标”等衍生列
权限控制展示根据角色显示不同内容

掌握CASE WHEN后,你的 SQL 查询能力会提升一个大台阶!它几乎是写复杂报表和数据分析 SQL 的必备武器。

如果你有具体业务场景(如“如何用 CASE WHEN 实现 pivot 表格”或“多表联查中的条件判断”),欢迎继续提问,我可以给出针对性示例!

需要专业的网站建设服务?

联系我们获取免费的网站建设咨询和方案报价,让我们帮助您实现业务目标

立即咨询