SQL语句实现横排 2

前一篇文章 SQL语句实现横排 介绍了在SQL SERVER 2000中实现数据横排的功能,这篇介绍在最新的SQLSERVER 2005中的实现方法。


SQL SERVER 2005中新增加了两个关系运算符 PIVOT/ UNPIVOT,能够实现表中的列转换到行,以及行到列的转换工作。

举例,还是先创建测试数据表

None.gif CREATE   TABLE  sales.salesByMonth
None.gif(
None.gif
year   char ( 4 ),
None.gif
month   char ( 3 ),
None.gifamount 
money ,
None.gif
PRIMARY   KEY  ( year month )
None.gif)
None.gif
None.gif
INSERT   INTO  sales.salesByMonth ( year month , amount)
None.gif
VALUES ( ' 2004 ' , ' Jan ' 789.0000 )
None.gif
INSERT   INTO  sales.salesByMonth ( year month , amount)
None.gif
VALUES ( ' 2004 ' , ' Feb ' 389.0000 )
None.gif
INSERT   INTO  sales.salesByMonth ( year month , amount)
None.gif
VALUES ( ' 2004 ' , ' Mar ' 8867.0000 )
None.gif
INSERT   INTO  sales.salesByMonth ( year month , amount)
None.gif
VALUES ( ' 2004 ' , ' Apr ' 778.0000 )
None.gif
INSERT   INTO  sales.salesByMonth ( year month , amount)
None.gif
VALUES ( ' 2004 ' , ' May ' 78.0000 )
None.gif
INSERT   INTO  sales.salesByMonth ( year month , amount)
None.gif
VALUES ( ' 2004 ' , ' Jun ' 9.0000 )
None.gif
INSERT   INTO  sales.salesByMonth ( year month , amount)
None.gif
VALUES ( ' 2004 ' , ' Jul ' 987.0000 )
None.gif
INSERT   INTO  sales.salesByMonth ( year month , amount)
None.gif
VALUES ( ' 2004 ' , ' Aug ' 866.0000 )
None.gif
INSERT   INTO  sales.salesByMonth ( year month , amount)
None.gif
VALUES ( ' 2004 ' , ' Sep ' 7787.0000 )
None.gif
INSERT   INTO  sales.salesByMonth ( year month , amount)
None.gif
VALUES ( ' 2004 ' , ' Oct ' 85576.0000 )
None.gif
INSERT   INTO  sales.salesByMonth ( year month , amount)
None.gif
VALUES ( ' 2004 ' , ' Nov ' 855.0000 )
None.gif
INSERT   INTO  sales.salesByMonth ( year month , amount)
None.gif
VALUES ( ' 2004 ' , ' Dec ' 5878.0000 )
None.gif
INSERT   INTO  sales.salesByMonth ( year month , amount)
None.gif
VALUES ( ' 2005 ' , ' Jan ' 7.0000 )
None.gif
INSERT   INTO  sales.salesByMonth ( year month , amount)
None.gif
VALUES ( ' 2005 ' , ' Feb ' 6868.0000 )
None.gif
INSERT   INTO  sales.salesByMonth ( year month , amount)
None.gif
VALUES ( ' 2005 ' , ' Mar ' 688.0000 )
None.gif
INSERT   INTO  sales.salesByMonth ( year month , amount)
None.gif
VALUES ( ' 2005 ' , ' Apr ' 9897.0000 )

我们想要得到类似这样的结果:
Year  Jan            Feb             Mar       ..............
----- ---------- ----------- -----------
2004 789.0000 389.0000     8867.0000 .............
2005 7.0000     6868.0000   688.0000 ..............

上一篇文章介绍的方法当然可以实现,但现在这里想要的列是固定的,不是动态的,就是12个月,所以也可以这样子来用:
None.gif SELECT   year ,
None.gif
SUM ( case   when   month   =   ' Jan '   then  amount  else   0   end AS   ' Jan ' ,
None.gif
SUM ( case   when   month   =   ' Feb '   then  amount  else   0   end AS   ' Feb ' ,
None.gif
SUM ( case   when   month   =   ' Mar '   then  amount  else   0   end AS   ' Mar ' ,
None.gif
SUM ( case   when   month   =   ' Apr '   then  amount  else   0   end AS   ' Apr ' ,
None.gif
SUM ( case   when   month   =   ' May '   then  amount  else   0   end AS   ' May ' ,
None.gif
SUM ( case   when   month   =   ' Jun '   then  amount  else   0   end AS   ' Jun ' ,
None.gif
SUM ( case   when   month   =   ' Jul '   then  amount  else   0   end AS   ' Jul ' ,
None.gif
SUM ( case   when   month   =   ' Aug '   then  amount  else   0   end AS   ' Aug ' ,
None.gif
SUM ( case   when   month   =   ' Sep '   then  amount  else   0   end AS   ' Sep ' ,
None.gif
SUM ( case   when   month   =   ' Oct '   then  amount  else   0   end AS   ' Oct ' ,
None.gif
SUM ( case   when   month   =   ' Nov '   then  amount  else   0   end AS   ' Nov ' ,
None.gif
SUM ( case   when   month   =   ' Dec '   then  amount  else   0   end AS   ' Dec '
None.gif
FROM  sales.salesByMonth
None.gif
GROUP   by   year


但这样事实上还是相当麻烦的,现在SQLSERVER2005中有更方便的实现方法。
None.gif SELECT   Year , [ Jan ] , [ Feb ] , [ Mar ] , [ Apr ] , [ May ] , [ Jun ] , [ Jul ] , [ Aug ] , [ Sep ] , [ Oct ] , [ Nov ] , [ Dec ]
None.gif
FROM  (
None.gif  
SELECT   year , amount,  month
None.gif  
FROM  sales.salesByMonth )  AS  salesByMonth
None.gifPIVOT ( 
SUM (amount)  FOR   month   IN
None.gif  (
[ Jan ] , [ Feb ] , [ Mar ] , [ Apr ] , [ May ] , [ Jun ] , [ Jul ] , [ Aug ] , [ Sep ] , [ Oct ] , [ Nov ] , [ Dec ] )
None.gif  ) 
AS  ourPivot
None.gif
ORDER   BY   Year

就是这样,很简单的用法,效果是完全一样的。

我们再尝试一下把year去掉:
None.gif SELECT   [ Jan ] , [ Feb ] , [ Mar ] , [ Apr ] , [ May ] , [ Jun ] , [ Jul ] , [ Aug ] , [ Sep ] , [ Oct ] , [ Nov ] , [ Dec ]
None.gif
FROM  (  SELECT  amount,  month
None.gif
FROM  sales.salesByMonth )  AS  salesByMonth
None.gifPIVOT ( 
SUM (amount)  FOR   month   IN
None.gif(
[ Jan ] , [ Feb ] , [ Mar ] , [ Apr ] , [ May ] , [ Jun ] , [ Jul ] , [ Aug ] , [ Sep ] , [ Oct ] , [ Nov ] , [ Dec ] )
None.gif
AS  ourPivot


得到的结果是:
Jan                 Feb                 Mar             ...
---------- ------------ -----------
796.0000     7257.0000     9555.0000     ...

同一个月份的数据累加到一起。


再给个微软官方的例子:
snap044.jpg



 

转载于:https://www.cnblogs.com/CrazyWill/archive/2006/04/14/374951.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值