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 的两种写法及其在不同场景下的条件转化方式。
这种形式将一个表达式与多个可能的值进行比较:
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_desc
FROM users;
更灵活,支持任意条件判断:
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 grade
FROM scores;
虽然不常见,但在某些复杂查询中可以用 CASE 转化动态条件。但需注意:CASE 返回值,不能直接替代逻辑表达式。
错误用法示例:
-- ❌ 错误:不能这样写
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
) t
WHERE category = 'A';
常用于自定义排序规则。
SELECT name, status
FROM tasks
ORDER 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;
基本上就这些。根据实际需求选择合适的 CASE 形式,能有效提升 SQL 的表达能力。
以上就是数据库mysql存储中case如何转化条件?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号