技术文摘
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 函数进行多重条件判断的方法,能让我们在数据处理和查询时更加高效、灵活,为数据库的管理和数据分析提供强大的支持,提升我们处理复杂业务逻辑的能力。
- Rollup:构建原理与简易实现
- Java 项目实战:构建股票区间交易盯盘系统
- 单例模式的多种写法竟如此之小?
- 曹大引领我学习 Go 之技术以外
- 7 个可加速前端开发的工具
- 或许这是迄今较好的 Git 教程
- Redis 作者谈处理开源项目维护精神压力之法
- Python 构建精美 GUI 之道
- 性能优化:缓存相关思考
- 2021 年 6 月编程语言排名:Python 有望超越 C 语言达巅峰
- 2021 年了,还在用 Jenkins?快来瞧瞧这些替代方案!
- GitHub 机密扫描现支持 PyPI 与 RubyGems
- 微信小程序基础架构之解析
- Python 代码小段破解加密 Zip 文件密码
- Java 编程中样板代码的技巧