[转]SQL 2005中pivot and unpivot的用法-阿里云开发者社区

开发者社区> 数据库> 正文
登录阅读全文

[转]SQL 2005中pivot and unpivot的用法

简介:
 .Pivot的用法体会
语句范例
select PN,[2006/5/30] as [20060530],[2006/6/2] as [20060602] 
from consumptiondata a 
Pivot (sum(a.M_qty) FOR a.M_date in ([2006/5/30],[2006/6/2])) as PVT  
order by PN 
  
Table结构 Consumptiondata (PN,M_Date,M_qty) 
order by PN可要可不要,并不重要,只是排序的作用 
  
关键的是红色部分,解析如下,select 大家都知道,PN ConsumptionData表中的一个Column, 
[2006/5/30]也是一个Column,他需要显示成[20060530],注意[2006/5/30]不是一个Value,而是一个Column.[2006/6/2][2006/5/30]一样
Pivot ( ........... ) as PVT这个结构是固定格式,没有什么需要特殊说明的,当然PVT随便你给他一个 NICKNAME ,it doesn't make any differences. 
sum(a.M_qty) 是我们希望显示出来的值,注意这个地方必须用汇总函数,否则语法不会过
FOR a.M_date in ([2006/5/30],[2006/6/2])for 表示汇总的值要显示在哪一个Column下面 
如果我们想让Sum(M_qty)显示在PN转换的Column下面,则可写为For PN, in 的清单表示我们关注哪些要查看的Column,注意再次强调是Column,不是Value. in的清单是Column清单,不是Value清单,M_dateValue转换成的Column清单
  
2.UnPivot 
--此段可以直接在Sql 2005中执行 
CREATE TABLE pvt (VendorID int, Emp1 int, Emp2 int,
Emp3 int, Emp4 int, Emp5 int)
GO
INSERT INTO pvt VALUES (1,4,3,5,4,4)
INSERT INTO pvt VALUES (2,4,1,5,5,5)
INSERT INTO pvt VALUES (3,4,3,5,4,4)
INSERT INTO pvt VALUES (4,4,2,5,5,4)
INSERT INTO pvt VALUES (5,5,1,5,5,5)
GO 
--select * from PVT 
--Unpivot the table.
SELECT VendorID, Employee, Orders 
FROM PVT
UNPIVOT ( 
 Orders FOR Employee IN ([Emp1], [Emp2], [Emp3], [Emp4], [Emp5])
)AS unpvt 
GO 
  

说明: Employee Column [Emp1]...为值, OrdersColumn [Emp1]...的值为值

本文转自深蓝居博客园博客,原文链接:http://www.cnblogs.com/studyzy/archive/2008/03/18/1110679.html,如需转载请自行联系原作者

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

分享: