SQL 行转列的运用

适用场景:须要将行数据转换成列数据spa

例子:code

如今有一个学生的成绩表blog

 

可是咱们须要将每一个学生的成绩聚集到一条数据上,这时候就能够用到行转列。数学

代码以下class

1、不使用  PIVOTim

1 SELECT  
2         MAX('学生'+CONVERT(NCHAR(10),[Stu_ID])) AS 学生
3        ,MAX(CASE WHEN Course='语文' THEN ISNULL(Score,0) ELSE 0 END) AS 语文成绩
4        ,MAX(CASE WHEN Course='数学' THEN ISNULL(Score,0) ELSE 0 END) AS 数学成绩
5        ,MAX(CASE WHEN Course='英语' THEN ISNULL(Score,0) ELSE 0 END) AS 英语成绩
6        ,CONVERT(DECIMAL(4,1),ROUND(AVG(Score),1))  AS 平均成绩
7   FROM [EFDemo].[dbo].[Table_1] 
8   GROUP BY Stu_ID

2、使用 PIVOT数据

   SELECT * FROM [EFDemo].[dbo].[Table_1]  AS P PIVOT(MAX(P.Score) FOR P.Course IN ([语文],[数学],[英语]) AS T

 

转换后查询到的结果集查询

相关文章
相关标签/搜索