1

次の形式のテーブルがあります

Country_Code | 1960年 | 1961年 | 1962年 | ..... | 2011年
------------------------------------------------
IND | va11 | va12 | va13 | ..... | va1x
オーストラリア | va21 | va22 | va23 | ..... | va2x
英語 | va31 | va32 | va33 | ..... | va3x

以下の形式に変換したい

Country_Code | 年 | 年 | 価値
---------------------------
IND | 1960年 | va11
IND | 1961年 | va12
IND | 1962年 | va13
.
.
IND | 2011年 | va1x
オーストラリア | 1960年 | va21
オーストラリア | 1961年 | va22
オーストラリア | 1962年 | va23
.
.
オーストラリア | 2011年 | va2x
英語 | 1960年 | va31
英語 | 1961年 | va32
英語 | 1962年 | va33
.
.
英語 | 2011年 | va3x

SQLクエリまたはSQLサーバーアセンブリによってこれをどのように達成できますか?

4

1 に答える 1

8

で完了できますUNPIVOT。既知の数の列がある場合は、値をハードコーディングできます。

select Country_Code, year, value
from yourtable
unpivot
(
  value 
  for year in ([1960], [1961], [1962], [2011])
) u

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

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

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

select @colsUnpivot = stuff((select ','+quotename(C.name)
         from sys.columns as C
         where C.object_id = object_id('yourtable') and
               C.name != 'Country_Code'
         for xml path('')), 1, 1, '')

set @query 
  = 'select country_code, year, value
     from yourtable
     unpivot
     (
        value
        for year in ('+ @colsunpivot +')
     ) u'

exec(@query)

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

を使用することもできますUNION ALL:

select country_code, '1960' year, 1960 value
from yourtable
union all
select country_code, '1961' year, 1961 value
from yourtable
union all
select country_code, '1962' year, 1962 value
from yourtable
union all
select country_code, '2011' year, 2011 value
from yourtable

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

于 2012-10-26T19:07:03.477 に答える