SQL--行转列and列转行

这篇用来总结一下使用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来合并所有科目列转行的结果以此实现整个数据集的列转行。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值