如何透视表?
Posted
技术标签:
【中文标题】如何透视表?【英文标题】:How to Pivot a Table? 【发布时间】:2011-02-01 00:37:37 【问题描述】:我的表有这个结构
subcode date rol1 rol2 rol3 rol4 rol5 rol6 upto rol60
--------------------------------------------------------------
mc1603 12/03/2011 p p a p p p a
mc1604 12/03/2011 p p a p p p a
mc1605 12/03/2011 p p a p p p a
mc1606 12/03/2011 p p a p p p a
这里
p=present
a=absent
这张表会变成
rollno mc1603 mc1604 mc1605 mc1606 date
-------------------------------------------------
rol1 p p p p 12/03/2011
rol2 p p p p 12/03/2011
rol3 p p a p 12/03/2011
【问题讨论】:
我的“动态支点”-sense 正在发挥作用 这不能做,因为你不知道要使用哪个日期。转置表中的日期属于rollno,而原始日期属于子代码。 【参考方案1】:以下是您将如何使用unpivot
和pivot
执行此操作:
静态查询:
create table #temp
(
subcode varchar(50),
date smalldatetime,
rol1 varchar(1),
rol2 varchar(1),
rol3 varchar(1),
rol4 varchar(1),
rol5 varchar(1),
rol6 varchar(1),
rol60 varchar(1)
)
insert into #temp values('mc1603', '03/12/2011', 'p', 'p', 'a', 'p', 'p', 'p', 'a')
insert into #temp values('mc1604', '03/12/2011', 'p', 'p', 'a', 'p', 'p', 'p', 'a')
insert into #temp values('mc1605', '03/12/2011', 'p', 'p', 'a', 'p', 'p', 'p', 'a')
insert into #temp values('mc1606', '03/12/2011', 'p', 'p', 'a', 'p', 'p', 'p', 'a')
SELECT p.rollNo, p.[mc1603], p.[mc1604], p.[mc1605], p.[mc1606], p.date
FROM
(
SELECT *
FROM
(
select subcode, date, rol1, rol2, rol3, rol4, rol5, rol6, rol60
from #temp
) x
UNPIVOT
(
presence FOR rollNo IN([rol1], [rol2], [rol3], [rol4], [rol5], [rol6], [rol60])
) unpiv
) x
PIVOT
(
max(presence)
FOR subcode IN([mc1603], [mc1604], [mc1605], [mc1606])
) p
drop table #temp
您也可以使用Dynamic SQL 执行此操作,但您需要先获取列列表,然后才能使用unpivot
然后pivot
:
动态查询:
-- get your roll no columns
DECLARE @cols AS VARCHAR(MAX),
@query AS VARCHAR(MAX);
SET @cols = STUFF((SELECT ',' + QUOTENAME(c.Name)
FROM sys.columns c
WHERE OBJECT_ID = OBJECT_ID('dbo.temp') AND c.NAME LIKE 'rol%'
FOR XML PATH(''), TYPE
).value('.', 'VARCHAR(MAX)')
,1,1,'')
-- get your dynamic string
set @query = 'SELECT p.rollNo, p.[mc1603], p.[mc1604], p.[mc1605], p.[mc1606], p.date
FROM
(
SELECT *
FROM
(
select subcode, date, ' + @cols + '
from temp
) x
UNPIVOT
(
presence FOR rollNo IN(' + @cols + ')
) unpiv
) x
PIVOT
(
max(presence)
FOR subcode IN([mc1603], [mc1604], [mc1605], [mc1606])
) p'
exec(@query)
结果:
rol1 p p p p 2011-03-12 00:00:00
rol2 p p p p 2011-03-12 00:00:00
rol3 a a a a 2011-03-12 00:00:00
rol4 p p p p 2011-03-12 00:00:00
rol5 p p p p 2011-03-12 00:00:00
rol6 p p p p 2011-03-12 00:00:00
rol60 a a a a 2011-03-12 00:00:00
【讨论】:
【参考方案2】:这是可以做到的,它被称为表格转置。在 SQL Server 上,它需要构建动态 SQL 语句并使用 EXEC 语句执行它。
【讨论】:
【参考方案3】:您必须旋转子代码列,然后取消旋转其他滚动列。
透视表将是 unpivot 语句中的派生表。
select * from
(
SELECT * FROM () Table0 PIVOT () Table1
) Table2
UNPIVOT () Table3
【讨论】:
以上是关于如何透视表?的主要内容,如果未能解决你的问题,请参考以下文章