在TSQL中,使用Pivot和Unpivot运算符将一个关系表转换成另外一个关系表,两个命令实现的操作是“相反”的,但是,pivot之后,不能通过unpivot将数据还原。这两个运算符的操作数比较复杂,记录一下自己的总结,以后用到时,作为参考。
一,Pivot用法
Pivot旋转的作用,是将关系表(table_source)中的列(pivot_column)的值,转换成另一个关系表(pivot_table)的列名:
table_source pivot ( aggregation_function(aggregated_column) for pivot_column in ([pivot_column_value_list]) ) as pivot_table_alias
透视操作的处理流程是:
- 对pivot_column和 aggregated_column的其余column进行分组,即,group by other_columns;
- 当pivot_column值等于某一个指定值,计算aggregated_column的聚合值;
在使用透视命令时,需要注意:
- pivot将table_source旋转成透视表(pivot_table)之后,不能再被引用
- pivot_column的列值,必须使用中括号([])界定符
- 必须显式命名pivot_table的别名
1,创建示例数据
use tempdb go drop table if exists dbo.usr go create table dbo.usr ( name varchar(10), score int, class varchar(8) ) go insert into dbo.usr values('a',20,'math'),('b',21,'math'),('c',22,'phy'),('d',23,'phy') ,('a',22,'phy'),('b',23,'phy'),('c',24,'math'),('d',25,'math') go