SqlServer中行转列的PIVOT函数

Oracle部分:

行专列pivot:

SELECT * FROM [StudentScores] /*数据源*/
AS P
PIVOT 
(
    SUM(Score/*行转列后 列的值*/) FOR 
    p.Subject/*需要行转列的列*/ IN ([语文],[数学],[英语],[生物]/*列的值*/)
) AS T

ps:注意第一行“select *  “”中的 * 号 不能换成列名

unpivot:

转换前:

month1month2month3month4
12131415
SELECT P.num,P.month
FROM 
(
    SELECT month1, month2, month3,month4
     FROM ProgrectDetail
)T
UNPIVOT 
(
    Num FOR month IN
    (month1 as '1月', month2 as '2月', month3 as '3月', month4 as '4月' )  
) P

转换后效果:

monthnum
1月12
2月13
3月14
4月15

 

sqlserver:

PIVOT函数中必须要包含一个聚合函数,聚合函数分别是:COUNT、SUM、MAX、MIN、AVG,针对不同的使用场景,该选择哪个聚合函数,意义都是不一样的,下面还是举例说明吧!

我建了如下一张销售表并且插入一下测试值:

[sql] view plain copy

  1. CREATE TABLE SalesOrder  
  2. (  
  3.     门店 VARCHAR(50),  
  4.     商品类型 VARCHAR(50),  
  5.     销售额 INT  
  6. )  
  7. INSERT INTO SalesOrder  
  8. SELECT  'ShopA','A',round(100+100*rand(),0) UNION ALL  
  9. SELECT  'ShopA','A',round(100+100*rand(),0) UNION ALL  
  10. SELECT  'ShopA','B',round(200+100*rand(),0) UNION ALL  
  11. SELECT  'ShopA','B',round(200+100*rand(),0) UNION ALL  
  12. SELECT  'ShopA','B',round(200+100*rand(),0) UNION ALL  
  13. SELECT  'ShopA','C',round(1000+100*rand(),0)UNION ALL  
  14. SELECT  'ShopB','A',round(100+100*rand(),0) UNION ALL  
  15. SELECT  'ShopB','A',round(100+100*rand(),0) UNION ALL  
  16. SELECT  'ShopB','B',round(200+100*rand(),0) UNION ALL  
  17. SELECT  'ShopB','C',round(1000+100*rand(),0)UNION ALL  
  18. SELECT  'ShopB','C',round(1000+100*rand(),0)UNION ALL  
  19. SELECT  'ShopC','A',round(100+100*rand(),0) UNION ALL  
  20. SELECT  'ShopC','B',round(200+100*rand(),0) UNION ALL  
  21. SELECT  'ShopC','B',round(200+100*rand(),0) UNION ALL  
  22. SELECT  'ShopC','B',round(200+100*rand(),0) UNION ALL  
  23. SELECT  'ShopC','B',round(200+100*rand(),0) UNION ALL  
  24. SELECT  'ShopC','C',round(1000+100*rand(),0)UNION ALL  
  25. SELECT  'ShopC','C',round(1000+100*rand(),0)  

下面我要在PIVOT行转列函数中,使用不同的聚合函数,更直观的统计各个“门店”以及各个”商品类型“的销售情况:

 

1.SUM:

[sql] view plain copy

  1. SELECT * FROM SalesOrder  
  2. PIVOT(SUM(销售额) FOR 商品类型 IN(A,B,C)) AS PVT  

统计的是各个门店,各个商品类型的总的销售额。

 

2.COUNT:

[sql] view plain copy

  1. SELECT * FROM SalesOrder  
  2. PIVOT(COUNT(销售额) FOR 商品类型 IN(A,B,C)) AS PVT  

统计的是各个门店,各个商品类型的销售量。

 

3.MAX:

[sql] view plain copy

  1. SELECT * FROM SalesOrder  
  2. PIVOT(MAX(销售额) FOR 商品类型 IN(A,B,C)) AS PVT  

统计的是各个门店,各个商品类型卖得最贵的销售额。

 

4.MIN:

[sql] view plain copy

  1. SELECT * FROM SalesOrder  
  2. PIVOT(MIN(销售额) FOR 商品类型 IN(A,B,C)) AS PVT  

和MAX相反,统计的是最便宜的销售额

 

5.AVG

[sql] view plain copy

  1. SELECT * FROM SalesOrder  
  2. PIVOT(AVG(销售额) FOR 商品类型 IN(A,B,C)) AS PVT  

统计的是各个门店,各个商品类型的销售额的平均值

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值