news 2026/4/3 5:58:21

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/4/2 14:01:08

基于PLC的交通灯控制系统交通信号灯十字路口红绿灯MCGS嵌入式组态仿真

详见主页个人简介获取MCGS组态仿真源文件讲解视频一、控制要求 交通灯是受启动按钮和停止按钮的控制,,当按下启动按钮时,受控制的信号灯开始工作,并循环工作,当按下停止按钮时,系统将维持在原有状态。 交通灯示意图如图…

作者头像 李华
网站建设 2026/4/2 14:37:58

PyTorch-CUDA-v2.8镜像优势分析:为什么它适合你的大模型项目?

PyTorch-CUDA-v2.8镜像优势分析:为什么它适合你的大模型项目? 在大模型训练日益成为AI研发核心环节的今天,一个稳定、高效且开箱即用的开发环境,往往决定了项目的启动速度和迭代效率。然而,现实中我们常常陷入这样的困…

作者头像 李华
网站建设 2026/2/27 19:11:47

嵌入式中的指针和地址常识

1. 指针变量本身也是一个变量,其储存的是一个地址,而这个值本身也有地址。*符号加上指针变量名,即获得这个指针变量的储存的地址所指向的值。&符号加变量名称,获得这个变量的所储存的数据的地址。这个变量也可以是指针变量。2…

作者头像 李华
网站建设 2026/3/29 22:37:33

DiskInfo下载官网之外的选择:监控GPU存储使用状态

DiskInfo下载官网之外的选择:监控GPU存储使用状态 在AI模型训练现场,你是否经历过这样的场景?深夜的实验跑了一半,突然弹出OOM(Out of Memory)错误——显存爆了。重启、调小batch size、删变量清缓存……但…

作者头像 李华
网站建设 2026/3/30 10:01:23

Jupyter Notebook转PDF报告:LaTeX环境安装指南

Jupyter Notebook转PDF报告:LaTeX环境安装指南 在现代AI研发流程中,一个常见的场景是:你刚刚完成了一轮模型训练,Notebook里堆满了实验数据、可视化图表和推导公式,接下来要向团队或客户提交一份正式的技术报告。手动复…

作者头像 李华
网站建设 2026/3/31 1:16:04

Jupyter Notebook扩展插件:如jupyter-themes美化界面

Jupyter Notebook界面美化与PyTorch-CUDA开发环境的融合实践 在深度学习项目日益复杂的今天,一个开发者每天可能要面对十几个小时的代码编写、模型调试和结果分析。而Jupyter Notebook作为最主流的交互式开发工具之一,其默认的白底黑字界面虽然清晰&…

作者头像 李华