技术文摘
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 语句为我们提供了强大的条件判断能力,无论是数据查询、统计分析还是数据更新,都能发挥重要作用。熟练掌握它的使用方法,能够帮助我们更高效地处理数据库中的数据,优化业务逻辑。
- Java代码报错,未绑定变量引发空指针异常,解决方法是什么
- XML文件标红报错运行正常但登录时后台报错如何排查
- JavaScript 定时器叠加后加速的原因
- 怎样实现跨位置同步显示 DOM 元素
- 构建具有乐观更新特性的数据表
- CSS垂直排列重叠问题:文字与div覆盖原因解析
- Ajax刷新JSP页面及遍历下拉框的方法
- Element-Plus 暗黑模式下的图标切换奥秘:i 标签里的 i 属性究竟是什么
- Flex布局中避免width: 0元素被挤占空间的方法
- 利用 CSS 过滤器与嵌套元素实现图中黑色不规则块的方法
- SVG 实现动态时间轴复杂效果的方法
- JavaScript获取点击元素相邻元素中的文字内容方法
- 在JavaScript中利用回调函数获取reCAPTCHA Token的方法
- jQuery printArea打印控件中DIV内容显示异常的解决方法
- SVG实现复杂动态UI效果(如时间轴)的方法