这篇用来总结一下使用SQL进行行转列和列转行的功能,因为最近在工作中实实在在用到了这个东西还是很实用的。
行转列
SQL语句:
SELECT
`name`,
SUM( CASE WHEN `subject` = 'chinese' THEN score ELSE NULL END ) chinese,
SUM( CASE WHEN `subject` = 'math' THEN score ELSE NULL END ) math,
SUM( CASE WHEN `subject` = 'english' THEN score ELSE NULL END ) english
FROM
study
GROUP BY
`name`;
列转行
SQL语句
SELECT
`name`,
'chinese' AS `subject`,
chinese AS score
FROM
study2 UNION ALL
SELECT
`name`,
'math' AS `subject`,
math AS score
FROM
study2 UNION ALL
SELECT
`name`,
'english' AS `subject`,
english AS score
FROM
study2
总结
行转列中由于原表只有两个字段,分别为name和subject,因此在select语句中也只能用这两个字段。使用SUM函数和CASE语句来完成行转列的功能,CASE用来判断subject是否等于要转成列的那个字段(也就是科目,比如语文or数学or英语),当条件为True时取出此时字段对应的科目成绩(score),反之赋值为null,最后对取到的值进行求和,求和时拿到的数据应该为(某一科目的成绩,null,null…),因此求和后的成绩就是原先科目的成绩,最后将其取个别名为该科目的名字。其他科目以此类推。
列转行中由于原表的字段为name和各个科目名字的字段,我们希望得到的是name、subject和score三个字段,因此我们使用union all来实现列转行功能。
具体来说是按照每个科目进行查询,提取出name字段,通过字符串’科目名字’ 赋值给新的字段subject,取出此科目名字对应字段的成绩赋值给score字段,以上是一个科目实现了列转行的功能。重复上述语句并使用union all来合并所有科目列转行的结果以此实现整个数据集的列转行。