【MySQL】探索 MySQL 中的 CASE WHEN 表达式


缘分让我们相遇乱世以外

命运却要我们危难中相爱

也许未来遥远在光年之外

我愿守候未知里为你等待

我没想到为了你我能疯狂到

山崩海啸没有你根本不想逃

我的大脑为了你已经疯狂到

脉搏心跳没有你根本不重要

🎵 邓紫棋《光年之外》


在数据库查询中,复杂的逻辑和条件处理是不可避免的。MySQL 提供了强大的 CASE WHEN 表达式,帮助我们在 SQL 查询中实现条件逻辑。CASE WHEN 表达式类似于编程语言中的 if-else 语句,允许我们根据不同条件返回不同的值。

什么是 CASE WHEN?

CASE WHEN 表达式用于实现条件分支逻辑,可以在 SELECT、UPDATE、DELETE 等语句中使用。其基本语法如下:

sql 复制代码
CASE
    WHEN condition1 THEN result1
    WHEN condition2 THEN result2
    ...
    ELSE resultN
END

其中,condition 是条件表达式,result 是条件满足时返回的结果。如果没有任何条件满足,则返回 ELSE 子句中的结果。如果省略了 ELSE 子句且没有任何条件满足,CASE WHEN 表达式将返回 NULL。

基本用法示例

让我们从一个简单的示例开始。假设我们有一个 students 表,包含学生的姓名和成绩。我们希望根据成绩给学生评级:85 分及以上为 '优秀',70 到 84 分为 '良好',60 到 69 分为 '及格',60 分以下为 '不及格'。

创建示例表并插入数据

sql 复制代码
CREATE TABLE students (
    id INT AUTO_INCREMENT PRIMARY KEY,
    name VARCHAR(50),
    score INT
);

INSERT INTO students (name, score) VALUES
('Alice', 92),
('Bob', 75),
('Charlie', 60),
('David', 58),
('Eva', 83);

使用 CASE WHEN 实现评分

sql 复制代码
SELECT
    name,
    score,
    CASE
        WHEN score >= 85 THEN '优秀'
        WHEN score >= 70 THEN '良好'
        WHEN score >= 60 THEN '及格'
        ELSE '不及格'
    END AS rating
FROM
    students;

查询结果:

diff 复制代码
+---------+-------+----------+
| name    | score | rating   |
+---------+-------+----------+
| Alice   |    92 | 优秀     |
| Bob     |    75 | 良好     |
| Charlie |    60 | 及格     |
| David   |    58 | 不及格   |
| Eva     |    83 | 良好     |
+---------+-------+----------+

进阶用法:嵌套 CASE WHEN 和复杂条件

我们还可以在 CASE WHEN 表达式中使用复杂的条件和嵌套 CASE WHEN。假设我们在 students 表中新增了一个 attendance 列,表示学生的出勤率。我们希望在评级的基础上,根据出勤率进一步细分评级。

添加出勤率数据

sql 复制代码
ALTER TABLE students ADD COLUMN attendance DECIMAL(5, 2);

UPDATE students SET attendance = 95.0 WHERE name = 'Alice';
UPDATE students SET attendance = 85.0 WHERE name = 'Bob';
UPDATE students SET attendance = 90.0 WHERE name = 'Charlie';
UPDATE students SET attendance = 60.0 WHERE name = 'David';
UPDATE students SET attendance = 70.0 WHERE name = 'Eva';

使用嵌套 CASE WHEN 和复杂条件

sql 复制代码
SELECT
    name,
    score,
    attendance,
    CASE
        WHEN score >= 85 THEN
            CASE
                WHEN attendance >= 90 THEN '优秀 - 高出勤'
                ELSE '优秀 - 低出勤'
            END
        WHEN score >= 70 THEN
            CASE
                WHEN attendance >= 80 THEN '良好 - 高出勤'
                ELSE '良好 - 低出勤'
            END
        WHEN score >= 60 THEN
            CASE
                WHEN attendance >= 70 THEN '及格 - 高出勤'
                ELSE '及格 - 低出勤'
            END
        ELSE
            CASE
                WHEN attendance >= 60 THEN '不及格 - 高出勤'
                ELSE '不及格 - 低出勤'
            END
    END AS detailed_rating
FROM
    students;

查询结果:

diff 复制代码
+---------+-------+-------------+-----------------+
| name    | score | attendance  | detailed_rating |
+---------+-------+-------------+-----------------+
| Alice   |    92 |        95.0 | 优秀 - 高出勤   |
| Bob     |    75 |        85.0 | 良好 - 高出勤   |
| Charlie |    60 |        90.0 | 及格 - 高出勤   |
| David   |    58 |        60.0 | 不及格 - 高出勤 |
| Eva     |    83 |        70.0 | 良好 - 低出勤   |
+---------+-------+-------------+-----------------+

使用 CASE WHEN 进行 UPDATE 操作

CASE WHEN 表达式不仅可以在 SELECT 语句中使用,还可以在 UPDATE 语句中使用。假设我们希望根据成绩和出勤率更新学生的评级信息。

添加评级列并更新数据

sql 复制代码
ALTER TABLE students ADD COLUMN rating VARCHAR(50);

UPDATE students
SET rating = CASE
    WHEN score >= 85 THEN
        CASE
            WHEN attendance >= 90 THEN '优秀 - 高出勤'
            ELSE '优秀 - 低出勤'
        END
    WHEN score >= 70 THEN
        CASE
            WHEN attendance >= 80 THEN '良好 - 高出勤'
            ELSE '良好 - 低出勤'
        END
    WHEN score >= 60 THEN
        CASE
            WHEN attendance >= 70 THEN '及格 - 高出勤'
            ELSE '及格 - 低出勤'
        END
    ELSE
        CASE
            WHEN attendance >= 60 THEN '不及格 - 高出勤'
            ELSE '不及格 - 低出勤'
        END
END;

验证更新结果

sql 复制代码
SELECT * FROM students;

查询结果:

diff 复制代码
+----+---------+-------+-------------+-----------------+
| id | name    | score | attendance  | rating          |
+----+---------+-------+-------------+-----------------+
|  1 | Alice   |    92 |        95.0 | 优秀 - 高出勤   |
|  2 | Bob     |    75 |        85.0 | 良好 - 高出勤   |
|  3 | Charlie |    60 |        90.0 | 及格 - 高出勤   |
|  4 | David   |    58 |        60.0 | 不及格 - 高出勤 |
|  5 | Eva     |    83 |        70.0 | 良好 - 低出勤   |
+----+---------+-------+-------------+-----------------+

总结

CASE WHEN 表达式是 MySQL 中一个非常强大的工具,能够帮助我们在 SQL 查询中实现复杂的条件逻辑。通过掌握 CASE WHEN 的使用,你可以在数据查询和更新中实现更为灵活和精细的控制。

在实际应用中,根据具体需求,灵活运用 CASE WHEN 表达式,可以极大地提高 SQL 查询的效率和可读性。希望这篇文章能够帮助你更好地理解和使用 MySQL 中的 CASE WHEN 表达式。

相关推荐
辞旧 lekkk5 小时前
【Qt】信号和槽
linux·开发语言·数据库·qt·学习·mysql·萌新
2301_809204706 小时前
JavaScript中严格模式use-strict对引擎解析的辅助.txt
jvm·数据库·python
zjy277776 小时前
mysql如何选择合适的索引类型_mysql索引设计实战
jvm·数据库·python
笨蛋不要掉眼泪6 小时前
Mysql架构揭秘:update语句的执行流程
数据库·mysql·架构
万邦科技Lafite6 小时前
京东item_get接口实战案例:实时商品价格监控全流程解析
java·开发语言·数据库·python·开放api·淘宝开放平台
秋97 小时前
ruoyi项目更换为mysql9.7.0数据库
数据库
Andya_net7 小时前
MySQL | MySQL 8.0 权限管理实践-精确赋予库、表只读等权限
android·数据库·mysql
筑梦之路9 小时前
harbor数据库报错权限异常如何处理——筑梦之路
数据库·harbor
czlczl200209259 小时前
理解 MySQL 行锁:两阶段锁协议与热点更新优化
数据库·mysql
AllData公司负责人9 小时前
通过Postgresql同步到Doris,全视角演示AllData数据中台核心功能效果,涵盖:数据入湖仓,数据同步,数据处理,数据服务,BI可视化驾驶舱
java·大数据·数据库·数据仓库·人工智能·python·postgresql