MySQL中CASE语句支持条件判断,分为简单CASE(类比switch)和搜索型CASE(类比if-else),可用于SELECT、WHERE、ORDER BY等场景;简单CASE比较表达式与值,搜索型支持复杂条件判断;在WHERE中需用逻辑表达式替代CASE返回值,不可直接使用;ORDER BY中可用CASE实现自定义排序;CASE从上至下执行,匹配即停止,建议始终添加ELSE避免NULL;简单CASE性能略优,合理使用可提升SQL表达能力。

在 MySQL 中,CASE 语句用于实现条件判断,类似于编程语言中的 if-else 或 switch-case 结构。它可以在 SELECT、WHERE、ORDER BY、UPDATE 等语句中使用,根据不同的条件返回不同的值。下面介绍 CASE 的两种写法及其在不同场景下的条件转化方式。
1. 简单 CASE 语法(类比 switch)
这种形式将一个表达式与多个可能的值进行比较:
CASE 表达式 WHEN 值1 THEN 结果1 WHEN 值2 THEN 结果2 ... ELSE 默认结果END
示例:根据用户等级显示中文描述
SELECT user_id, level, CASE level WHEN 1 THEN '初级' WHEN 2 THEN '中级' WHEN 3 THEN '高级' ELSE '未知等级' END AS level_descFROM users;
2. 搜索型 CASE 语法(类比 if-else)
更灵活,支持任意条件判断:
CASE WHEN 条件1 THEN 结果1 WHEN 条件2 THEN 结果2 ... ELSE 默认结果END
示例:根据分数划分等级
SELECT student_id, score, CASE WHEN score >= 90 THEN '优秀' WHEN score >= 80 THEN '良好' WHEN score >= 60 THEN '及格' ELSE '不及格' END AS gradeFROM scores;
3. 在 WHERE 中使用 CASE(条件过滤)
虽然不常见,但在某些复杂查询中可以用 CASE 转化动态条件。但需注意:CASE 返回值,不能直接替代逻辑表达式。
错误用法示例:
PHP Apache和MySQL 网页开发初步
本书全面介绍PHP脚本语言和MySOL数据库这两种目前最流行的开源软件,主要包括PHP和MySQL基本概念、PHP扩展与应用库、日期和时间功能、PHP数据对象扩展、PHP的mysqli扩展、MySQL 5的存储例程、解发器和视图等。本书帮助读者学习PHP编程语言和MySQL数据库服务器的最佳实践,了解如何创建数据库驱动的动态Web应用程序。
385 查看详情
-- ❌ 错误:不能这样写WHERE CASE role WHEN 'admin' THEN id > 0 ELSE id > 100 END
正确做法:拆分为逻辑表达式
WHERE (role = 'admin' AND id > 0) OR (role != 'admin' AND id > 100)
或者,在计算字段中使用 CASE 再过滤:
SELECT *FROM ( SELECT *, CASE WHEN role = 'admin' THEN 'A' ELSE 'B' END AS category FROM users) tWHERE category = 'A';
4. 在 ORDER BY 中使用 CASE 排序
常用于自定义排序规则。
SELECT name, statusFROM tasksORDER BY CASE status WHEN 'urgent' THEN 1 WHEN 'pending' THEN 2 WHEN 'done' THEN 3 ELSE 4 END;
也可以结合条件:
ORDER BY CASE WHEN active = 1 THEN sort_order ELSE 999 END;
5. 注意事项
CASE 语句从上到下逐个判断,一旦满足某个条件就返回结果,后续条件不再检查,顺序很重要。如果未匹配任何条件且没有 ELSE 子句,返回 NULL。ELSE 是良好实践,建议始终包含以避免意外 NULL。性能方面:简单 CASE 通常比搜索型稍快,但差别不大。
基本上就这些。根据实际需求选择合适的 CASE 形式,能有效提升 SQL 的表达能力。
以上就是数据库mysql存储中case如何转化条件?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/857661.html
微信扫一扫
支付宝扫一扫