技术文摘
MySQL 中 CASE WHEN 的使用方法
2025-01-14 18:48:12 小编
MySQL 中 CASE WHEN 的使用方法
在 MySQL 数据库的操作中,CASE WHEN 语句是一个功能强大且灵活的工具,它允许我们根据条件进行逻辑判断,并返回不同的结果。掌握 CASE WHEN 的使用方法,能够极大地提升数据处理和查询的效率。
CASE WHEN 语句的基本语法结构有两种形式。一种是简单 CASE 表达式:CASE 列名 WHEN 值1 THEN 结果1 WHEN 值2 THEN 结果2 … ELSE 结果 END;另一种是搜索 CASE 表达式:CASE WHEN 条件1 THEN 结果1 WHEN 条件2 THEN 结果2 … ELSE 结果 END。
简单 CASE 表达式适用于根据某一列的不同固定值返回不同结果的场景。例如,在一个学生成绩表中,有“score”列存储成绩。我们想要根据成绩划分等级,60 分以下为“不及格”,60 到 79 分为“及格”,80 到 89 分为“良好”,90 分及以上为“优秀”。可以使用如下查询:
SELECT score,
CASE
WHEN score < 60 THEN '不及格'
WHEN score >= 60 AND score < 80 THEN '及格'
WHEN score >= 80 AND score < 90 THEN '良好'
ELSE '优秀'
END AS grade
FROM student_scores;
搜索 CASE 表达式则更灵活,能根据不同的条件进行判断。比如,我们要统计一个订单表中不同金额区间的订单数量。订单金额小于 100 元的为小额订单,100 到 500 元为中额订单,大于 500 元为大额订单。查询语句如下:
SELECT
SUM(CASE WHEN amount < 100 THEN 1 ELSE 0 END) AS small_order_count,
SUM(CASE WHEN amount >= 100 AND amount < 500 THEN 1 ELSE 0 END) AS medium_order_count,
SUM(CASE WHEN amount >= 500 THEN 1 ELSE 0 END) AS large_order_count
FROM orders;
在实际应用中,CASE WHEN 还可以用于更新数据。例如,要将员工表中职位为“developer”的员工薪资提高 10%,可以这样操作:
UPDATE employees
SET salary = CASE
WHEN position = 'developer' THEN salary * 1.1
ELSE salary
END;
MySQL 中的 CASE WHEN 语句为我们提供了强大的条件判断能力,无论是数据查询、统计分析还是数据更新,都能发挥重要作用。熟练掌握它的使用方法,能够帮助我们更高效地处理数据库中的数据,优化业务逻辑。
- 如何在Oracle中查看表对应的序列
- 如何在oracle中查询时间范围
- 如何在oracle中创建新用户并赋予权限
- 如何在oracle中显示所有表
- Oracle如何查询特定时间段内的数据记录
- 如何备份oracle用户下的表
- 如何在oracle中查看表空间
- 如何在oracle中建立dblink
- 如何在oracle中查看被锁的表
- 如何在oracle中查看哪些表有分区
- 如何在oracle中查看数据库包含哪些表
- 如何使用oracle的substr截取地址
- Oracle如何查询时间段内的数据流量
- 如何使用 Oracle 的 import table 导入 pde 文件
- 如何使用命令将oracle表数据备份到文件夹