2

我正在寻找不使用 PIVOT 运算符(旧的 ms-sql 服务器)来部分透视表的查询。桌子:

id-------item---------rank1---------rank2
231------it1--------- 1 ----------- 1
231------it2-------- 1 ----------- 2 
231------it3--------- 1 ----------- 3
154------it4--------- 3 ----------- 4
154------it2--------- 1 ----------- 2
155------it2--------- 1 ----------- 2
156------it3 -------- 2 ----------- 2
156------it1 -------- 1 ----------- 1

预期结果:

id---------item1----item2----item3---item*... 
231 -------it1------it2---------it3 
154--------it2------it4 
155--------it2 
156--------it1------it3

rank1 和 rank2 排序

我在谷歌上搜索,但我发现的解决方案太复杂而无法应用。

4

1 回答 1

1

在 SQL Server 中,您可以使用row_number为每个id组分配一个行号。然后你可以使用这个max(case(...技巧来旋转:

select  id
,       max(case when rn = 1 then item end) as item1
,       max(case when rn = 2 then item end) as item2
,       max(case when rn = 3 then item end) as item3
from    (
        select  row_number() over (partition by id
                    order by rank1, rank2) as rn
        ,       *
        from    YourTable
        ) as SubQueryAlias
group by
        id

不使用动态 SQL 就没有 N 个项目的通用解决方案。

于 2012-09-22T09:50:29.973 回答