mysql 行数据转为列

来源:互联网 发布:strikingly 用 建站 编辑:程序博客网 时间:2024/05/16 04:52
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()函数取最大值(红色圆圈圈起来的值就是这组数据的对应列的最大值)之后,就变成了下面的效果 

0 0
原创粉丝点击