在两个组上使用SQL unpivot

时间:2015-11-30 17:26:06

标签: sql-server unpivot

我有一张表格如下:

Name    ValueA1    ValueA2    ValueA3    ValueB1    ValueB2    ValueB3    QtyA1    QtyA2    QtyA3    QtyB1    QtyB2    QtyB3
John    1          2          3          4          5          6          100      200      300      150      250      350
Dave    11         12         13         14         15         16         100      200      300      150      250      350

我可以使用unpivot来获取值:

select [Name]
     , Replace(u.[Period],'Value','') as [Period]
     , u.[Value]
from Table1
unpivot
(
  [Value]
  for [Period] in ([ValueA1], [ValueA2], [ValueA3], [ValueB1], [ValueB2], [ValueB3])
  ) u;

SQL Fiddle

不过我想同时获得ValueQty在同一行上的列,我想落得是:

Name    Number  Value   Qty
John    A1      1       100
John    A2      2       200
John    A3      3       300
John    B1      4       150
John    B2      5       250
John    B3      6       350
Dave    A1      11      100
Dave    A2      12      200
Dave    A3      13      300
Dave    B1      14      150
Dave    B2      15      250
Dave    B3      16      350

到目前为止我所拥有的(根本不起作用):

select [Name]
     , Replace(u.[Period],'Value','') as [Period]
     , u.[Value]
     , u2.[Value]
from Table1
unpivot
(
  [Value]
  for [Period] in ([ValueA1], [ValueA2], [ValueA3], [ValueB1], [ValueB2], [ValueB3])
  ) u

 unpivot

 (
   [Qty]
   for [Period] in ([QtyA1], [QtyA2], [QtyA3], [QtyB1], [QtyB2], [QtyB3])

 ) u2;

我正在尝试使用unpivot做什么?

1 个答案:

答案 0 :(得分:2)

您可以通过在values子句中指定对来使用简单的方法:

declare @table table (Name varchar(10), ValueA1 int, ValueA2 int, QtyA1 int, QtyA2 int);
insert into @table
select 'John', 1, 2, 100, 200 union all     
select 'Dave', 11, 12, 100, 200;


select  Name, Number, Value, Qty 
from    @table
cross 
apply   (   values 
            ('A1', ValueA1, QtyA1),
            ('A2', ValueA2, QtyA2)
        ) c (number, value, qty);
  

如果您使用的是旧版本的MSSQL,则可能需要使用此版本    而不是上面的值子句:

cross 
apply (   select 'A1', ValueA1, QtyA1 union all
          select 'A2', ValueA2, QtyA2
      ) c (number, value, qty);

<强>返回:

Name    Number  Value   Qty
John    A1      1       100
John    A2      2       200
Dave    A1      11      100
Dave    A2      12      200