mysql 行数据转为列

mysql实现行转列

一开始表里面的数据如下

最后想要呈现的效果如下

sql语言如下
SELECT student_id,name,MAX(case WHEN moth = 1 then money END) as january,MAX(case WHEN moth=2 then money END) as feb,SUM(money) from student_info GROUP BY student_id,`name`

原理如下
先按月份条件逐行列出
SELECT student_id,name,case WHEN moth = 1 then money END as january,case WHEN moth=2 then money END as feb from student_info


加上 group by 关键字进行分组 和max关键字进行聚合之后

SELECT student_id,name,max(case WHEN moth = 1 then money END) as january,max(case WHEN moth=2 then money END) as feb from student_info GROUP BY student_id,`name`

     图片由



   经过max()函数取最大值(红色圆圈圈起来的值就是这组数据的对应列的最大值)之后,就变成了下面的效果 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值