技术文摘
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 语句为我们提供了强大的条件判断能力,无论是数据查询、统计分析还是数据更新,都能发挥重要作用。熟练掌握它的使用方法,能够帮助我们更高效地处理数据库中的数据,优化业务逻辑。
- DELL R710 服务器 centos 系统安装配置方法
- Win10 蓝牙已配对设备无法删除的解决之道
- 如何在 Linux 系统中用 vmstat 命令显示虚拟内存状态
- Windows10 与 CentOS 双系统安装全攻略
- Win11 打开 jpeg 图片的方法及 Windows11 设置 JPEG 图片打开格式技巧
- Win11 如何更改文件类型?Win11 修改文件后缀的办法
- Win11 Beta 预览版 Build 22621.450/22622.450(KB5016700)更新发布及内容详情
- MS-DOS 6.22 装入 U 盘与硬盘的办法
- Win11 打开 html 格式文件的方法是什么
- 如何更改 Linux 系统的默认网关
- Win11 桌面图标大小设置方法解析
- 深度 Linux 账户图片更换方法:用户头像设置指南
- MSDN 中 MS-DOS 6.22 的安装之法
- U盘安装正版 Win10 系统的详细步骤
- deepin 系统安装成功网速缓慢如何解决