0

誰かが私のデータをピボットする方法を教えてくれませんか? 私は持っている:

RowID Dimension Value
1 Country Italy
1 Year 2011
1 GDP 4
1 Population 6
2 Country Spain
2 Year 2011
2 GDP 7
2 Population 5

私はそのような方法で欲しい:

RowID Country Year GDP Population
1 Italy 2011 4 6
2 Spain 2011 7 5

PS 私は MS SQL Server 2008 R2 Express Edition を使用しています。PIVOT を使用しようとしましたが、NULL で多くの行が返されたため、わかりませんでした。

4

1 に答える 1

1

これに使えますPIVOT。すべての値がわかっている場合、これはハードコーディングできます。

select *
from
(
  select rowid, dimension, value
  from yourtable
) src
pivot
(
  max(value)
  for dimension in ([Country], [Year], [GDP], [Population])
) piv

デモで SQL Fiddle を参照してください

PIVOTまたは、関数にアクセスできない場合は、次のように集計を使用できCASEます。

select rowid,
  max(case when dimension = 'country' then value end) country,
  max(case when dimension = 'Year' then value end) Year,
  max(case when dimension = 'GDP' then value end) GDP,
  max(case when dimension = 'Population' then value end) Population
from yourtable
group by rowid

デモで SQL Fiddle を参照してください

値の数が不明な場合は、動的 SQL を使用できます。

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

select @cols = STUFF((SELECT distinct ',' + QUOTENAME(Dimension) 
                    from yourtable
            FOR XML PATH(''), TYPE
            ).value('.', 'NVARCHAR(MAX)') 
        ,1,1,'')

set @query = 'SELECT rowid, ' + @cols + ' from 
             (
                select rowid, dimension, value
                from yourtable
            ) x
            pivot 
            (
                max(value)
                for dimension in (' + @cols + ')
            ) p '

execute(@query)

デモで SQL Fiddle を参照してください

于 2012-11-10T23:25:07.007 に答える