PIVOT函数的格式如下 PIVOT(<聚合函数>([聚合列值]) FOR [行转列前的列名] IN([行转列后的列名1],[行转列后的列名2],[行转列后的列名3]
CREATE TABLE #Temp
(TypeClass NVARCHAR(200),
Name NVARCHAR(200),
Price int)
INSERT INTO #Temp (TypeClass ,Name ,Price)
VALUES ('白班', 'A' ,10)
INSERT INTO #Temp (TypeClass ,Name ,Price)
VALUES ( '晚班' ,'A' ,20)
INSERT INTO #Temp (TypeClass ,Name ,Price)
VALUES ('白班', 'B' ,100)
INSERT INTO #Temp (TypeClass ,Name ,Price)
VALUES ( '晚班' ,'B' ,200)
/*
相要达到的效果
TypeClass会有很多,不只是白班晚班还有其它,用于也会有很多用户
===================
用户 白班 晚班
A 10 20
B 100 200
/*
select
*
from
(
select
Name
,typeClass,price
from
#
Temp
)
as
infotest
pivot(
sum
(price)
for
typeClass
in
([白班],[晚班]))
as
lie
GO