码迷,mamicode.com
首页 > 数据库 > 详细

mysql中case使用

时间:2018-06-10 15:35:25      阅读:221      评论:0      收藏:0      [点我收藏+]

标签:jpg   core   res   esc   sele   else   成绩   语句   use   

前言:遇到这样一个需求,有一门成绩,成绩中只记录了学生的分数,现在需要统计学生的分数等级,100-90分为优秀,90-60分为及格,60-0分为不及格。这个需求就可以用CASE语句来表达。

case语句分为简单case语句和可搜索case语句。

1.简单case的语法为

CASE  case_expression
   WHEN when_expression_1 THEN commands
   WHEN when_expression_2 THEN commands
   ...
   ELSE commands
END

这种适合固定的值,比如性别,1男,2女这种

例子:将下图中sex换成汉字的性别,1男,2女。

技术分享图片

SELECT
	*, (
		CASE sex
		WHEN 1 THEN
			‘男‘
		WHEN 2 THEN
			‘女‘
		END
	) ‘性别‘
FROM
	`user`

结果如下图

技术分享图片

2.可搜索case语句,这种适应表达式与一组不同的值进行匹配。

语法为

CASE
    WHEN condition_1 THEN commands
    WHEN condition_2 THEN commands
    ...
    ELSE commands
END

例子就是最开始提到的

技术分享图片

SELECT
	*,
	(
		CASE 
		WHEN  score>=90 THEN
			‘优秀‘
		WHEN score>=60 THEN
			‘及格‘
		ELSE
			‘不及格‘
		END
	) ‘等级‘
FROM
	math
ORDER BY score DESC

结果如下

技术分享图片

mysql中case使用

标签:jpg   core   res   esc   sele   else   成绩   语句   use   

原文地址:https://www.cnblogs.com/kacha886/p/9162696.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!