0

我的测试表中有 3 列,例如

ID | m_id    | S_m_id                                 
---------- --------------
1  |  1      |    1                  
1  |  2      |    3                  
1  |  3      |    4                  
1  |  5      |    6                  
2  |  1      |    1                  
2  |  2      |    3                  
2  |  3      |    4                  
3  |  5      |    6

我想将基于第 1 列的第 2 列和第 3 列合并为一行。结果应该是这样的

ID | merge_id                                 
---------- --------------
1  |  1,1;2,3;3,4;5,6                  
2  |  1,1;2,3;3,4                  
3  |  5,6       
4

1 回答 1

4

您需要的功能是listagg()在聚合时进行字符串连接。您还需要首先将 id 连接在一起:

select id,
       listagg(m_id || ',' || s_m_id, ';') within group (order by m_id) as merge_ids
from test t
group by id;

顺便说一句,结果数据不正确(因为所有三行的 id 都相同)。这可能是反对票的原因。

编辑(回应评论):

在原始示例中有两个分隔符,一个是逗号(在 id 之间),一个是分号(在行之间)。您可以将其中任何一个替换为'|'管道分隔符。

于 2013-06-17T13:08:20.157 回答