[转]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_date Value 转换成的 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,如需转载请自行联系原作者

相关文章
|
8月前
|
SQL 程序员
sql中的distinct用法
`DISTINCT`在SQL中用于返回唯一不同的值,消除结果集中的重复行。基本用法包括:1) 选择单列唯一值,如`SELECT DISTINCT department FROM employees;`
|
5月前
|
SQL 存储 关系型数据库
|
6月前
|
SQL 大数据 HIVE
每天一道大厂SQL题【Day33】行转列,列转行
每天一道大厂SQL题【Day33】行转列,列转行
57 0
每天一道大厂SQL题【Day33】行转列,列转行
|
7月前
|
SQL 数据库
SQL DISTINCT 用法总结
SQL DISTINCT 用法总结
|
SQL 存储 Oracle
通过sql做数据透视表,数据库表行列转换(pivot和Unpivot用法)(一)
在mssql中大家都知道可以使用pivot来统计数据,实现像excel的透视表功能 一、MSsqlserver中我们通常的用法
408 0
|
SQL
SQL中行转列、列转行
SQL中行转列、列转行
255 0
SQL中行转列、列转行
|
SQL 分布式计算 Spark
【译】SQL Pivot介绍
本文介绍SQL Pivot以及如何使用该功能
2407 0

热门文章

最新文章

下一篇
开通oss服务