1

我有以下格式的表格

国家代码 | 1960 | 1961 | 1962 | ..... | 2011
------------------------------------------------
IND | va11 | va12 | va13 | ..... | va1x
澳大利亚 | va21 | va22 | va23 | ..... | va2x
英文 | va31 | va32 | va33 | ..... | va3x

我想把它转换成下面的格式

国家代码 | 年份 | 价值
--------------------------
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 server 程序集来实现?

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 回答