前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >[转]SQL 2005中pivot and unpivot的用法

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

作者头像
深蓝studyzy
发布2022-06-16 13:37:37
7030
发布2022-06-16 13:37:37
举报
文章被收录于专栏:深蓝居

.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]...为值, Orders以Column [Emp1]...的值为值

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2008-03-18,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档