SQL 挑战将行连接到每个组的末尾

SQL Challenge concatenate rows to the end of every group

我有以下table,我需要将数据展平。

从这里开始

table 1

id      val1   val2   ....valn 
-----------------------------------
1         a      z
1         b      x
1         c      v 
2         a      w
2         b      q 
..n

到这里

id      val1_1   val2_1   ....valn_1   val1_2  val2_2 ... valn_2  ....  val1_n...valn_n 
-----------------------------------
1         a      z                        b       x
2         a      w                        b       q 
..n

有什么想法吗?

我已经使用游标做了一些事情,但是它有点讨厌并且有一些错误。枢轴?

是的,您需要一个主元,但您还需要计算一个行号以作为主元。但是,鉴于这是一个多列数据透视表,仅使用条件聚合可能更容易。

我建议您为行号选择一个合适的顺序

SELECT
  id,
  val1_1 = MAX(CASE WHEN t.rn = 1 THEN t.val1 END),
  val2_1 = MAX(CASE WHEN t.rn = 1 THEN t.val2 END),
  val3_1 = MAX(CASE WHEN t.rn = 1 THEN t.val3 END),
--  ...........
  val1_2 = MAX(CASE WHEN t.rn = 2 THEN t.val1 END),
  val2_2 = MAX(CASE WHEN t.rn = 2 THEN t.val2 END),
  val3_2 = MAX(CASE WHEN t.rn = 2 THEN t.val3 END),
--  ...........
FROM (
    SELECT *,
        rn = ROW_NUMBER() OVER (PARTITION BY t.rn ORDER BY (SELECT 1))
    FROM table1 t
) t
GROUP BY t.id;