news 2026/3/7 9:06:02

SQL之CASE WHEN用法详解_sql case when

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
SQL之CASE WHEN用法详解_sql case when

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 表格”或“多表联查中的条件判断”),欢迎继续提问,我可以给出针对性示例!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/5 12:23:53

YOLOv5 Anchor K-means聚类:自定义数据集锚框生成

YOLOv5 Anchor K-means聚类:自定义数据集锚框生成 在工业质检的产线上,一台视觉检测设备正高速扫描电路板——微小的焊点缺陷需要被精准识别。然而,使用标准YOLOv5模型训练时,小目标漏检严重,召回率始终难以突破80%。问…

作者头像 李华
网站建设 2026/2/20 17:14:46

Anaconda虚拟环境备份与恢复:保护PyTorch开发配置

Anaconda虚拟环境备份与恢复:保护PyTorch开发配置 在深度学习项目中,你是否经历过这样的场景?本地调试一切正常,模型训练顺利收敛,信心满满地将代码推送到远程服务器准备大规模训练时,却突然报出 ImportErr…

作者头像 李华
网站建设 2026/3/5 21:50:51

无需繁琐配置!PyTorch-CUDA-v2.8镜像一键开启GPU算力之旅

无需繁琐配置!PyTorch-CUDA-v2.8镜像一键开启GPU算力之旅 在深度学习项目中,你是否曾经历过这样的场景:刚准备好复现一篇论文的代码,却发现环境报错不断——torch.cuda.is_available() 返回 False,提示找不到合适的 CU…

作者头像 李华
网站建设 2026/3/4 4:47:22

PyTorch-CUDA-v2.8镜像安装全攻略:轻松配置GPU加速深度学习环境

PyTorch-CUDA-v2.8镜像安装全攻略:轻松配置GPU加速深度学习环境 在当今AI研发一线,你是否也曾被这样的场景困扰过?刚拿到一台新服务器,满心期待地准备跑通第一个模型训练脚本,结果却被“CUDA driver version is insuf…

作者头像 李华
网站建设 2026/3/6 20:22:09

Git Rebase vs Merge:维护干净PyTorch项目历史记录

Git Rebase vs Merge:维护干净PyTorch项目历史记录 在深度学习项目的日常开发中,你是否曾面对过这样的场景?当你打开 git log --graph,满屏的分叉与合并节点像一张错综复杂的蜘蛛网,根本无法快速理清某次模型性能提升究…

作者头像 李华