SQL分组多列统计(GROUP BY后按条件分列统计)

最近遇到一个问题,需要对一张表做统计,这个统计有什么特别之处值得我记录了下来呢?大家知道SQL中聚合函数GROUP BY的结果一般为一列,即多个值通过聚合函数运算统计到一起,但是如何将不同条件的值统计到不同列中呢,即按条件统计到多个列中。举个栗子:

YEARTYPEVALUE
20151100
20152200
20161150
20162300
20163100

 

 

 

 

 

 

转为:

YEARTYPE1TYPE2TYPE3
20151002000
2016150300100

 

 

 

 

这时候我们除了用到GROUP BY之外还需要CASE WHEN,SQL如下:

SELECT year,
 SUM(CASE WHEN type=1 THEN value ELSE 0 END) as type1,
 SUM(CASE WHEN type=2 THEN value ELSE 0 END) as type2,
 SUM(CASE WHEN type=3 THEN value ELSE 0 END) as type3,
 FROM table_test GROUP BY year

 

小小的知识点,记录下来并分享给有需要的人。

P.S. 这里TYPE是写死的,有没有办法能更灵活一点呢?

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值