技术文摘
MySQL 中利用 CASE 函数进行多重条件判断的方法
MySQL 中利用 CASE 函数进行多重条件判断的方法
在 MySQL 数据库的操作中,经常会遇到需要根据不同条件进行不同处理的情况。CASE 函数作为一种强大的条件判断工具,能帮助我们轻松实现这一需求。
CASE 函数有两种使用形式:简单 CASE 函数和搜索 CASE 函数。
简单 CASE 函数的语法结构为:CASE 表达式 WHEN 值1 THEN 结果1 WHEN 值2 THEN 结果2 … ELSE 结果 END。它用于对一个表达式进行简单的等值判断。例如,我们有一个学生成绩表 students,包含列 student_id、name 和 score。现在要根据成绩划分等级:60 分以下为“不及格”,60 到 79 分为“中等”,80 到 89 分为“良好”,90 分及以上为“优秀”。可以使用如下查询:
SELECT student_id, name,
CASE
WHEN score < 60 THEN '不及格'
WHEN score >= 60 AND score < 80 THEN '中等'
WHEN score >= 80 AND score < 90 THEN '良好'
ELSE '优秀'
END AS grade
FROM students;
搜索 CASE 函数则更加灵活,语法为:CASE WHEN 条件1 THEN 结果1 WHEN 条件2 THEN 结果2 … ELSE 结果 END。它允许我们对不同的条件进行判断。比如,在一个商品表 products 中,有列 product_id、name 和 price。我们想根据价格区间对商品进行分类:价格小于 100 的为“低价商品”,100 到 500 的为“中等价位商品”,大于 500 的为“高价商品”。查询语句如下:
SELECT product_id, name,
CASE
WHEN price < 100 THEN '低价商品'
WHEN price >= 100 AND price <= 500 THEN '中等价位商品'
ELSE '高价商品'
END AS product_type
FROM products;
利用 CASE 函数不仅可以在 SELECT 语句中实现数据的条件展示,还可以在 UPDATE、INSERT 等语句中发挥作用。例如,在 UPDATE 语句中,可以根据特定条件更新不同的列值。
掌握 MySQL 中 CASE 函数进行多重条件判断的方法,能让我们在数据处理和查询时更加高效、灵活,为数据库的管理和数据分析提供强大的支持,提升我们处理复杂业务逻辑的能力。
- JMM 的理解
- 与糟糕的开发人员共事
- Go 语言的酷炫之处
- 20 世纪 20 年代人工智能与数据科学的编程语言 Go
- Vue 数据更新页面未更新的 7 种情形汇总与拓展
- 鲜为人知的多种 CSS 居中办法!
- Python 网页数据抓取与存储实战教程
- Java 基础知识重温,你是否记得
- 解析 JavaScript 中的浅拷贝和深拷贝
- 把你的 Virtual dom 渲染至 Canvas
- 实例:基于 CNN 和 Python 的肺炎检测实现
- C++ 初始化中的那些坑,你是否也曾遭遇?
- 构建即时消息应用(七):Access 页面
- SSR 的利弊究竟如何?细述SSR的优劣之处
- 世界上超级科技大厂的软件测试之道