6

私のソースデータテーブルは

MemID Condition_ID Condtion_Result
----------------------------------
1     C1           0
1     C2           0
1     C3           0
1     C4           1
2     C1           0
2     C2           0
2     C3           0
2     C4           0

作成したい予想ビューは....

MemID C1 C2 C3 C4
------------------
1     1  0  0  1
2     0  0  0  1

その他の条件はこちら。上記のソース テーブルの例では、特定の MemID に対して 4 行のみです。この数は、実際の状況では異なります。私のピボット テーブル (またはその他のソリューション) は、任意の数の条件結果を選択し、それらを列として表示する必要があります。どうやってするの ?

4

1 に答える 1

23

を使用する必要がありますPIVOT。変換する列の値がわかっている場合は STATIC PIVOT を使用するか、実行時まで列が不明な場合は DYNAMIC PIVOT を使用できます。

静的ピボット ( SQL Fiddle with Demoを参照):

select *
from 
(
    select memid, Condition_id, Condition_Result
    from t
) x
pivot
(
    sum(condition_result)
    for condition_id in ([C1], [C2], [C3], [C4])
) p

動的ピボット( SQL Fiddle with Demoを参照):

DECLARE @cols AS NVARCHAR(MAX),
    @query  AS NVARCHAR(MAX)

SET @cols = STUFF((SELECT distinct ',' + QUOTENAME(c.condition_id) 
            FROM t c
            FOR XML PATH(''), TYPE
            ).value('.', 'NVARCHAR(MAX)') 
        ,1,1,'')


set @query = 'SELECT memid, ' + @cols + ' from 
            (
                select MemId, Condition_id, condition_result
                from t
           ) x
            pivot 
            (
                sum(condition_result)
                for condition_id in (' + @cols + ')
            ) p '


execute(@query)

どちらも同じ結果を生成します。

于 2012-07-23T18:03:48.417 に答える