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 ENDcondition 是一个返回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;