在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 CASE sex WHEN 1 THEN '男' WHEN 2 THEN '女' ELSE '人妖' END FROM t
2)SELECT 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 搜索函数
SELECT CASE WHEN age<5 THEN '小孩',WHEN age>=5 AND age <18 THEN '少年' ELSE '老了' END FROM t
跟第一种写法也差不了多少,
CASE WHEN '布尔表达式' THEN ‘结果表达式1’ ELSE '结果表达式2' END
暂时我不知道这两种写法有哪些显著的区别,以后再更新,先知道怎么用就行了