MySQL CASE WHEN THEN ELSE END简单用法

mysql中CASE  WHEN  THEN  ELSE  END是一种常用的条件表达式,类似if/else语句。

CASE两种格式

(一)简单Case函数 (ELSE 可省略)

CASE column
    WHEN  value1 THEN  result1 
    WHEN  value2 THEN  result2
    ......
    ELSE resultN
END 

其中column是需要查询的字段名,查询数据等于value1时,返回result1,不等于value1时,会一直向下匹配,匹配上就会返回相对应的result值;如果没有满足的value值,就会返回ELSE子句中的result值;如果没有满足的value值并且ELSE子句省略了,就会返回null。

(二)Case搜索函数 (ELSE 可省略):

CASE 
    WHEN condition1 THEN result1 
    WHEN condition2 THEN result2 
    ......
    ELSE resultN
END 

condition 是一个返回boolean的表达式。 如果结果为true,那么 CASE 表达式的结果就是符合条件的 result。 如果结果为false,那么以相同方式搜寻之后的 WHEN 子句。 如果没有 WHEN condition 为true,那么 case 表达式的结果就是在 ELSE 子句里的值。 如果省略了 ELSE 子句而且没有匹配的条件, 结果为null。

CASE函数简单应用

一、根据已知数据按照其他方式数字进行分组查询显示

如下数据一(工资表):

根据salary数值等级来分组查询人数,SQL如下:

SELECT 
        CASE WHEN salary <= 10000 THEN '1' 
             WHEN salary > 10000 AND salary <= 20000  THEN '2' 
             WHEN salary > 20000 THEN '3' 
        ELSE NULL END salaryGrade, 
        COUNT(*) 
FROM    salary 
GROUP BY 
        CASE WHEN salary <= 10000 THEN '1' 
             WHEN salary > 10000 AND salary <= 20000  THEN '2' 
             WHEN salary > 20000 THEN '3' 
        ELSE NULL END; 

查询结果如下:

二、一条SQL语句根据不同条件查询分组

如下数据二(成绩表):

根据名称和科目分组查询分数,SQL语句如下:

SELECT name, 
       SUM(CASE subject WHEN "语文" THEN number ELSE 0 END) chineseGrade, -- 语文分数
       SUM(CASE subject WHEN "数学" THEN number ELSE 0 END) mathGrade,    -- 数学分数
       SUM(CASE subject WHEN "英语" THEN number ELSE 0 END) englishGrade  -- 英语分数
FROM grade
GROUP BY name; 

查询结果如下:

三、根据条件选择性的修改数据

例如:数据一(工资表)

修改条件:salary10000以下的员工,增加20%;salary10001~20000的员工,增加15%;salary大于20000的不变。

如果用两条SQL语句来修改数据,很容易出现重复操作的错误数据。

 -- salary10000以下的员工,增加20%
UPDATE salary SET salary = salary * 1.2 WHERE salary <= 10000;
 -- salary10001~20000的员工,增加15%
UPDATE salary SET salary = salary * 1.15 WHERE salary >= 10001 AND salary <= 20000;

所以必须得一个SQL语句来实现这个功能。Case函数可以实现:

UPDATE salary 
SET salary = 
	CASE WHEN salary <= 10000 THEN salary * 1.2
             WHEN salary >= 10001 AND salary <= 20000 THEN salary * 1.15
             ELSE salary -- 必须加上 ELSE salary,否则不用修改的数据都会被改成null
	END; 

 

  • 1
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值