これに使えます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 を参照してください