适用场景:须要将行数据转换成列数据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
转换后查询到的结果集查询