2014-02-17 106 views
3

如果我有一個包含未知數量成員的團隊表,是否有一種方法可以使數據透視表動態變化?數據透視表可以使用未知數量的列嗎?

create table #t (
    team varchar (20), member varchar (20) 
) 
insert into #t values ('ERP', 'Jack') 
insert into #t values ('ERP', 'John') 
insert into #t values ('ERP', 'Mary') 
insert into #t values ('ERP', 'Tim') 
insert into #t values ('CRM', 'Robert') 
insert into #t values ('CRM', 'Diana') 

select * from #t 

select team, [1] as teamMember1, /* 1st select */ 
    [2] as teamMember2, [3] as teamMember3 
from 
(select team , member, row_number() /* 3rd select */ 
    over (partition by team order by team) as rownum 
from #t) a 
pivot (max(member) for rownum in ([1], [2], [3])) as pvt 

drop table #t 
+3

我認爲你正在尋找這樣的:http://stackoverflow.com/questions/2922797/t-sql-pivot-possibility-of-creating - 表 - 列 - 從行值。 Itzik Ben-Gan關於如何構建動態PIVOT的例子。 –

回答

0

爲什麼是的,是的。這是我幾年前編寫的一個腳本,用於解決類似的問題,最終通過給用戶Excel並洗手來解決這個問題。我很抱歉它沒有配置你的示例數據,但希望它很容易遵循。

希望幫助,

約翰

--------------START QUERY-------------- 
-- Example Table 
CREATE TABLE #glbTestTable 
(
    ProviderID INT, 
    Total  INT, 
    PaymentDate SMALLDATETIME 
) 

--So the dates insert properly 
SET DATEFORMAT dmy 

-- Populate Example Table 
INSERT INTO #glbTestTable VALUES (232, 12200, '12/01/09') 
INSERT INTO #glbTestTable VALUES (456, 10200, '12/01/09') 
INSERT INTO #glbTestTable VALUES (563, 11899, '02/03/09') 
INSERT INTO #glbTestTable VALUES (221, 5239, '13/04/09') 
INSERT INTO #glbTestTable VALUES (987, 7899, '02/03/09') 
INSERT INTO #glbTestTable VALUES (1, 1234, '02/08/09') 
INSERT INTO #glbTestTable VALUES (2, 4321, '02/07/09') 
INSERT INTO #glbTestTable VALUES (3, 5555, '02/06/09') 

-- Raw Output 
SELECT * 
FROM #glbTestTable 

-- Build Query for Pivot -- 
DECLARE @pvtColumns VARCHAR(MAX) 
SET @pvtColumns = '' 

-- Grab up to the first 1023 "Columns" that we want to use in Pivot Table. 
-- Tables can only have 1024 columns at a maximum 
SELECT TOP 1023 @pvtColumns = @pvtColumns + '[' + CONVERT(VARCHAR, PaymentDate, 103) + '], ' 
FROM (SELECT DISTINCT PaymentDate FROM #glbTestTable) t_distFP 

-- Create PivotTable Query 
DECLARE @myQuery VARCHAR(MAX) 
SET @myQuery = ' 
SELECT ProviderID, ' + LEFT(@pvtColumns, LEN(@pvtColumns) - 1) + ' 
FROM (SELECT ProviderID, PaymentDate, Total 
    FROM #glbTestTable) AS SourceTable 
PIVOT 
(
    SUM(Total) 
    FOR PaymentDate IN (' + LEFT(@pvtColumns, LEN(@pvtColumns) - 1) + ') 
) AS PivotTable' 

-- Run the Pivot Query 
EXEC(@myQuery) 

-- Cleanup 
DROP TABLE #glbTestTable 
---------------END QUERY--------------- 
相關問題