PIVOT函数,行转列

  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 #Tempas infotest

pivot(sum(price) for typeClass in([白班],[晚班]))as lie

GO

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值