这可能是使用UNPIVOT吗?或任何其他逻辑......?

时间:2014-01-15 09:24:54

标签: sql sql-server sql-server-2008 unpivot

我的源表如下:

declare @table table (EvalId int, ProjectId int,RT1 int,RT2 int,RT3 int)

insert into @table
select 21 evalID,17 ProjectID, 0 RT1,8 Rt2, 7 RT3
union all
select 21 evalID,18 ProjectID, 4 RT1,6 Rt2, 1 RT3

select * from @table

所需的输出是:

EvalId  ProjectId   RT  Rating
21      17          RT1 0
21      17          RT2 8
21      17          RT3 7
21      18          RT1 4
21      18          RT2 6
21      18          RT3 1

如何使用UNPIVOT做到这一点?

1 个答案:

答案 0 :(得分:2)

;WITH CTE
as
 (
  select * from @table
    UNPIVOT
    (
         Rating FOR RT IN (RT1,RT2,RT3)
    ) as pv
)
SELECT EvalId   
       ,ProjectId   
       ,RT
       ,Rating
FROM CTE

结果集

╔════════╦═══════════╦═════╦════════╗
║ EvalId ║ ProjectId ║ RT  ║ Rating ║
╠════════╬═══════════╬═════╬════════╣
║     21 ║        17 ║ RT1 ║      0 ║
║     21 ║        17 ║ RT2 ║      8 ║
║     21 ║        17 ║ RT3 ║      7 ║
║     21 ║        18 ║ RT1 ║      4 ║
║     21 ║        18 ║ RT2 ║      6 ║
║     21 ║        18 ║ RT3 ║      1 ║
╚════════╩═══════════╩═════╩════════╝