如何解决SQL Challenge 将行连接到每个组的末尾
我有下表,我需要展平数据。
从这里
表一
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;
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。