SQL Server 如何实现行转列
- 原创
- |
- 浏览:7341
- |
- 更新:
在 SQL Server 的日常使用中,做数据统计或报表时,需要将列的值旋转为列名进行呈现。下面介绍在 SQL Server 中实现行转列的方法。
方法/步骤
1、创建临时表
创建一张临时表#TMP,保存学生课程的分数,并插入一些测试数据。
2、要实现的效果
将列“课程”的值作为列名呈现,相当于汇聚同一个学生的所有成绩作为一行记录。
3、使用 CASE WHEN 实现
使用 CASE WHEN 语句进行遍历判断,可以很方便的将列值转换成列名。
但是,如果需要转换的列值过多,那SQL语句就会变得比较冗余,因此 CASE WHEN 适合列值较少的情况。
4、PIVOT 关系运算符介绍
PIVOT 的基本语法是对列进行聚合,指定要成为列名的列值以及具体列名。
这里要聚合的是“分数”,要指定的是“课程”,具体列名是“美术、音乐、绘画”
- 本页面未经许可获取自百度经验
5、用 PIVOT 实现
将临时表的实际值填入PIVOT 的基本语法中,即可实现行转列。
6、两者比较
仔细比较 CASE WHEN 和 PIVOT,可以发现两者在一定程度上其实是一一对应关系,只是 PIVOT 的写法更加简洁和实用,同时理解和写法也更复杂一些。
END
经验内容仅供参考,如果您需解决具体问题(尤其法律、医学等领域),建议您详细咨询相关领域专业人士。
作者声明:本篇经验系本人依照真实经历原创,未经许可,谢绝转载。
展开阅读全部