mysql触发器中case语句_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 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

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

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值