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 语句为我们提供了强大的条件判断能力,无论是数据查询、统计分析还是数据更新,都能发挥重要作用。熟练掌握它的使用方法,能够帮助我们更高效地处理数据库中的数据,优化业务逻辑。

TAGS: 使用方法 MySQL SQL语句 CASE WHEN

欢迎使用万千站长工具!

Welcome to www.zzTool.com