0

0

mysql中CASE WHEN如何使用_mysql CASE WHEN操作

P粉602998670

P粉602998670

发布时间:2025-12-01 10:01:09

|

930人浏览过

|

来源于php中文网

原创

答案:CASE WHEN 是 MySQL 中用于实现条件逻辑的语句,支持在 SELECT、UPDATE、ORDER BY 中根据条件返回不同值;其有两种形式:简单 CASE 表达式用于等值比较,搜索型 CASE 表达式用于复杂条件判断;常用于分数评级、状态排序、薪资调整等场景;执行时按顺序匹配,一旦满足即停止,因此条件顺序至关重要。

mysql中case when如何使用_mysql case when操作

在 MySQL 中,CASE WHEN 是一种条件判断语句,可以在查询中实现类似编程语言中的 if-else 逻辑。它常用于 SELECT、UPDATE、ORDER BY 等语句中,根据不同的条件返回不同的值。

基本语法结构

MySQL 的 CASE WHEN 有两种使用方式:

1. 简单 CASE 表达式(类比 switch

将一个表达式与多个可能的值进行比较。

CASE value  
    WHEN compare_value1 THEN result1  
    WHEN compare_value2 THEN result2  
    ELSE default_result  
END

2. 搜索型 CASE 表达式(类比 if-else)

对多个条件进行判断,更灵活,支持复杂逻辑。

CASE  
    WHEN condition1 THEN result1  
    WHEN condition2 THEN result2  
    ELSE default_result  
END

在 SELECT 查询中使用示例

假设有一张学生表 students,包含字段:name(姓名)、score(分数),我们想根据分数划分等级:

DeepL
DeepL

DeepL是一款强大的在线AI翻译工具,可以翻译31种不同语言的文本,并可以处理PDF、Word、PowerPoint等文档文件

下载

SELECT 
    name,
    score,
    CASE  
        WHEN score >= 90 THEN '优秀'
        WHEN score >= 80 THEN '良好'
        WHEN score >= 60 THEN '及格'
        ELSE '不及格'
    END AS grade
FROM students;

这个查询会为每个学生返回对应的等级。

在 ORDER BY 中动态排序

可以结合 CASE WHEN 实现自定义排序规则。例如按状态优先级排序:

SELECT status, name FROM tasks
ORDER BY 
    CASE 
        WHEN status = 'urgent' THEN 1
        WHEN status = 'high'   THEN 2
        WHEN status = 'normal' THEN 3
        ELSE 4
    END;

这样就能按自定义优先级对任务状态排序。

在 UPDATE 中使用条件更新

也可以在 UPDATE 语句中使用 CASE WHEN 批量处理不同情况:

UPDATE employees 
SET salary = CASE 
    WHEN performance = 'A' THEN salary * 1.1
    WHEN performance = 'B' THEN salary * 1.05
    ELSE salary
END;

根据员工绩效动态调整薪资。

基本上就这些。CASE WHEN 能让 SQL 更具表现力和灵活性,尤其适合数据分类、状态映射、动态计算等场景。注意 WHEN 条件是顺序执行的,一旦匹配就不再往下判断,所以条件顺序很重要。不复杂但容易忽略细节。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

679

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

320

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

346

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1095

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

357

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

675

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

574

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

415

2024.04.29

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

27

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.8万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 794人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号