mysql中使用case when语句

在web开发过程中,很多时候良好的sql不仅可以加快数据响应时间,更重要可以省略大量的后端代码。比如说对大量数据的分组,统计(求和,求差,求平均,求百分比等等),排序,如果可以放到sql里面去做,还是在sql里面解决的好。我今天在做改一个需求,一个数据统计的接口响应时间达到19s,吓死宝宝了。打开源码看,套路就是从数据库取出需要的数据,进行处理,再去数据库取,再回来处理,一个大循环里包着两条sql,这不太好吧.jpg。

我是第一次使用case when语句,今天用了下,发现很强大,能做很多事情。

SELECT t3.code,t3.name,t3.allcount AS allcount, t3.allcount*100/9999 AS newcount FROM
(SELECT t2.*,t1.name,
SUM(CASE WHEN t2.state='0' THEN 1 ELSE 0 END) AS allcount
FROM nemas t1 LEFT JOIN alert t2
ON t1.code=t2.code WHERE t2.reason IS NOT NULL GROUP BY t1.name) AS t3
GROUP BY t3.name,t3.code

两种格式的写法:

1.简单case函数:

举栗子

1)SELECT * FROM CASE sex WHEN 1 THEN '男' WHEN 2 THEN '女' ELSE '人妖' END FROM t

2)SELECT * FROM CASE age WHEN age<5 THEN '小孩',WHEN age>=5 AND age <18 THEN '少年' ELSE '老了'  END FROM t

CASE '初始表达式'  WHEN '条件表达式'  THEN ‘结果表达式1’ ELSE '结果表达式2' END

如果初始表达式=条件表达式,返回结果表达式1,否则结果表达式2,没有结果表达式2就返回null

2.case 搜索函数

扫描二维码关注公众号,回复: 3127139 查看本文章

SELECT * FROM CASE WHEN age<5 THEN '小孩',WHEN age>=5 AND age <18 THEN '少年' ELSE '老了'  END FROM t

跟第一种写法也差不了多少,

CASE WHEN '布尔表达式'  THEN ‘结果表达式1’ ELSE '结果表达式2' END

暂时我不知道这两种写法有哪些显著的区别,以后再更新,先知道怎么用就行了

猜你喜欢

转载自www.cnblogs.com/hunger-c/p/9625342.html