形式1
形式2
形式3
有时候可能会有这样的需求: 将一张表的所有列名转做为数据的一列数据,将一列数据作为整张表的列名
当列比较多时,只用PIVOT是解决不了的,经过研究,需要将UNPIVOT 和 PIVOT 联合使用
如上面的3个图,我们最终需要把形式1转换为形式3. 然而单用PIvot 解决不了问题,需要分两步转换
第一步:先通过UNPIVOT将所有列转换到数据中的一列,如形式2
第二步:通过PIVOT将另外一列数据作为列名
这样就实现了将源表的某列数据与列名互换.
1 SELECT [Week] AS [Date],[Total] AS WeeklyTotal 2 ,[Monday] 3 ,[Tuesday] 4 ,[Wednesday] 5 ,[Thursday] 6 ,[Friday] 7 ,[Saturday] 8 ,[Sunday] 9 FROM