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


缘分让我们相遇乱世以外
命运却要我们危难中相爱
也许未来遥远在光年之外
我愿守候未知里为你等待
我没想到为了你我能疯狂到
山崩海啸没有你根本不想逃
我的大脑为了你已经疯狂到
脉搏心跳没有你根本不重要
                     🎵 邓紫棋《光年之外》


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

什么是 CASE WHEN?

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

CASEWHEN condition1 THEN result1WHEN condition2 THEN result2...ELSE resultN
END

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

基本用法示例

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

创建示例表并插入数据

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 实现评分

SELECTname,score,CASEWHEN score >= 85 THEN '优秀'WHEN score >= 70 THEN '良好'WHEN score >= 60 THEN '及格'ELSE '不及格'END AS rating
FROMstudents;

查询结果:

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

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

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

添加出勤率数据

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 和复杂条件

SELECTname,score,attendance,CASEWHEN score >= 85 THENCASEWHEN attendance >= 90 THEN '优秀 - 高出勤'ELSE '优秀 - 低出勤'ENDWHEN score >= 70 THENCASEWHEN attendance >= 80 THEN '良好 - 高出勤'ELSE '良好 - 低出勤'ENDWHEN score >= 60 THENCASEWHEN attendance >= 70 THEN '及格 - 高出勤'ELSE '及格 - 低出勤'ENDELSECASEWHEN attendance >= 60 THEN '不及格 - 高出勤'ELSE '不及格 - 低出勤'ENDEND AS detailed_rating
FROMstudents;

查询结果:

+---------+-------+-------------+-----------------+
| 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 语句中使用。假设我们希望根据成绩和出勤率更新学生的评级信息。

添加评级列并更新数据

ALTER TABLE students ADD COLUMN rating VARCHAR(50);UPDATE students
SET rating = CASEWHEN score >= 85 THENCASEWHEN attendance >= 90 THEN '优秀 - 高出勤'ELSE '优秀 - 低出勤'ENDWHEN score >= 70 THENCASEWHEN attendance >= 80 THEN '良好 - 高出勤'ELSE '良好 - 低出勤'ENDWHEN score >= 60 THENCASEWHEN attendance >= 70 THEN '及格 - 高出勤'ELSE '及格 - 低出勤'ENDELSECASEWHEN attendance >= 60 THEN '不及格 - 高出勤'ELSE '不及格 - 低出勤'END
END;

验证更新结果

SELECT * FROM students;

查询结果:

+----+---------+-------+-------------+-----------------+
| 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 表达式。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/21234.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

每周统计-20240531

用于测试程序的稳定性: 龙虎榜: 成交额: 封成比: 收盘前放量: 开盘抢筹: 封单额:

论文阅读:Correcting Motion Distortion for LIDAR HD-Map Localization

目录 概要 Motivation 整体架构流程 技术细节 小结 论文地址:http://arxiv.org/pdf/2308.13694.pdf 代码地址:https://github.com/mcdermatt/VICET 概要 激光雷达的畸变矫正是一个非常重要的工作。由于扫描式激光雷达传感器需要有限的时间来创建…

YOLOv5训练数据集的配置文件格式与使用技巧

文章目录 一 概述二 配置文件说明2.1 官方配置文件解析2.2 自定义数据集配置文件2.3 其他格式指定数据集路径2.4 多个数据集路径指定 三 总结注意事项 一 概述 本文档主要记录 YOLOv5 算法在进行模型训练前,关于加载数据集的配置文件的说明。 默认情况下&#xff…

RPC-----RCF

RPC RPC(Remote Procedure Call Protocol)——远程过程调用协议。 RCF

linux命令:调试必备工具dmesg

在服务器上进行芯片调试时,我们会遇到各种各样的问题,很多问题与操作系统相关。此时就需要了解操作系统发生了哪些事件。 dmesg 是linux系统中用来打印或控制内核缓冲区内容的命令。这个环形缓冲区记录了系统启动以来发生的各种事件消息,包括…

ChatTTS改良版 - 高度逼真的人类情感文本生成语音工具(TTS)本地一键整合包下

先介绍下ChatTTS 和之前发布的 Fish Speech 类似,都是免费开源的文本生成语音的AI软件,但不同的是,ChatTTS测试下来,对于人类情感语调的模仿,应该是目前开源项目做的最好的,是一款高度接近人类情感、音色、…

MYSQL学习笔记-基础篇

一、SQL 1、DDL 2、DML 3、DQL 4、DCL 主要包括用户管理和权限控制 1)DCL-管理用户 --查询用户 use mysql select * from user;--新增用户 CREATE USER 用户名主机名 IDENTIFIED BY 密码eg: create user hahalocalhost identied by 123; cre…

ppo-clip的本质以及它为什么是另一种ppo-KL-penalty

显然&#xff0c;clip在优势函数A>0且重采样比例过大时截断了上限&#xff0c;在优势函数A<0且重采样比例过小时也截断了负值的上限。 我以第一种情况解释clip的作用。 首先&#xff0c;所有选择的action都是RL中你希望增大概率的action。 当A>0时&#xff0c;说明这…

WordPress中借助Table of Contents Plus+Widget Options插件,实现仅在文章侧边栏显示文章目录的功能

本文转自博主的个人博客&#xff1a;https://blog.zhumengmeng.work,欢迎大家前往查看。 原文链接&#xff1a;点我访问 序言&#xff1a;今天心血来潮&#xff0c;写了一篇文章&#xff0c;忽然发现自己的文章极少有目录&#xff0c;这对于长文章的阅读来说是十分不利的&#…

【自动驾驶】针对低速无人车的线控底盘技术

目录 术语定义 一般要求 操纵装置 防护等级 识别代号 技术要求 通过性要求 直线行驶稳定性 环境适应性要求 功能安全要求 信息安全要求 故障处理要求 通信接口 在线升级(OTA) 线控驱动 动力性能 驱动控制响应能力 线控制动 行车制动 制动响应能力 线控转向 总体要求 线控…

车联网安全入门——ICSim模拟器使用

文章目录 车联网安全入门——ISCim模拟器使用介绍主要特点&#xff1a;使用场景&#xff1a; 安装使用捕获can流量candumpcansnifferwiresharkSavvyCAN主要特点&#xff1a;使用场景&#xff1a; 重放can报文cansendSavvyCAN 总结 车联网安全入门——ISCim模拟器使用 &#x1…

SQL刷题笔记day8——SQL进阶——表与索引操作

目录 1 创建一张新表 2 修改表 3 删除表 4 创建索引 5 删除索引 1 创建一张新表 我的答案 create table if not exists user_info_vip (id int(11) primary key auto_increment Comment自增ID, # 有了主键就不用写not nul了 uid int(11) unique not null Comment用户ID, …

发现真正的诉求

在不久前&#xff0c;我在负责一个项目&#xff0c;设计了一个方案。但是&#xff0c;与我一同合作的同事对其中的一个设计点持有异议。我们尝试讨论解决&#xff0c;但似乎没有找到共识。然而&#xff0c;尽管双方的观点没有达成一致&#xff0c;我们都清楚地表达了自己的想法…

272 基于matlab的形态滤波和局域值分解(LMD)的齿轮故障诊断

基于matlab的形态滤波和局域值分解&#xff08;LMD&#xff09;的齿轮故障诊断&#xff0c;GUI交互界面。通过形态滤波对一维信号进行降噪处理&#xff0c;并通过LMD局部均值分解提取故障信号&#xff0c;最后提取处故障频率。程序已调通&#xff0c;可直接运行。 272 形态滤波…

[AIGC] DAG模型在任务调度中有什么优势?

DAG(Directed Acyclic Graph&#xff0c;有向无环图)在任务调度中的应用带来了以下优势&#xff1a; 清晰的任务依赖关系&#xff1a;在DAG模型中&#xff0c;任务以节点的形式存在&#xff0c;任务间的依赖关系通过有向边来表示。这使得任务关系清晰明了&#xff0c;易于理解和…

Mysql学习经验总结(一)

Mysql的简介&#xff1a; MySql是一个开源的关系型数据库管理系统&#xff0c;广泛应用于Web应用程序的数据存储和管理。它支持多用户并发访问&#xff0c;具有高性能、稳定可靠、易于使用和管理的特点。 MySql官网提供了详细的文档、下载、社区等资源&#xff0c;官网的地址…

微信小程序的服务调取

微信小程序的服务调取概述 微信小程序允许开发者通过网络请求与服务器进行交互&#xff0c;从而实现数据的上传和下载。这是通过小程序提供的API&#xff0c;如wx.request、wx.downloadFile、wx.uploadFile等来完成的。这些API使得小程序可以从远程服务器获取数据&#xff0c;…

文档智能开源软件

文档智能介绍&#xff1a; 文档智能通常指的是利用人工智能技术来处理和分析文档内容&#xff0c;以实现自动化、智能化的文档管理。文档智能的应用领域非常广泛&#xff0c;包括但不限于&#xff1a; 1. **文档识别**&#xff1a;使用OCR&#xff08;光学字符识别&#xff0…

Java+SVNCloud+Mysql课程设计

文章目录 1、主要内容2、所需准备3、与sql访问的中间类&#xff1a;SqlMessage4、窗口界面5、main方法 1、主要内容 课程设计&#xff0c;主要通过Javas wing创建窗口&#xff0c;jdbc连接云端mysql数据库进行基本操作&#xff0c;支持随机生成数据并用动态展示数据结果。 先…

一种最大重叠离散小波包特征提取和支持向量机的ECG心电信号分类方法(MATLAB 2018)

目前小波分析算法常采用Mallat快速算法。该算法由与滤波器卷积、隔点采样和隔点插零等三个环节组成。由于实际使用的滤波器并不具有理想频域特性&#xff0c;使得在标准二进小波算法中存在着频率混叠和小波系数失真等缺点&#xff0c;在标准二进小波包算法中还存在频带错乱现象…