我有一个表,我想拉一行每个id与字段值连接。

例如,在我的表格中,我有这样的:

TM67 | 4  | 32556
TM67 | 9  | 98200
TM67 | 72 | 22300
TM99 | 2  | 23009
TM99 | 3  | 11200

我想输出:

TM67 | 4,9,72 | 32556,98200,22300
TM99 | 2,3    | 23009,11200

在MySQL中,我能够使用聚合函数GROUP_CONCAT,但这似乎在这里不起作用…PostgreSQL有类似的功能吗,或者有其他方法可以实现这个功能?


当前回答

根据我的经验,我使用bigint作为列类型。所以下面的代码为我工作。我使用的是PostgreSQL 12。

类型转换发生在这里。(::文本)。

string_agg(some_column::text, ',')

其他回答

希望下面的Oracle查询能正常工作。

Select First_column,LISTAGG(second_column,',') 
    WITHIN GROUP (ORDER BY second_column) as Sec_column, 
    LISTAGG(third_column,',') 
    WITHIN GROUP (ORDER BY second_column) as thrd_column 
FROM tablename 
GROUP BY first_column

假设表your_table有三列(name, id, value),查询如下:

  select name, 
         array_to_string(array_agg(id), ','), 
         array_to_string(array_agg(value), ',')
    from your_table
group by name
order by name
;

"TM67"  "4,9,72"    "32556,98200,22300"
"TM99"  "2,3"       "23009,11200"

KI

试着这样做:

select field1, array_to_string(array_agg(field2), ',')
from table1
group by field1;

根据我的经验,我使用bigint作为列类型。所以下面的代码为我工作。我使用的是PostgreSQL 12。

类型转换发生在这里。(::文本)。

string_agg(some_column::text, ',')

从9.0开始,这变得更容易了:

SELECT id, 
       string_agg(some_column, ',')
FROM the_table
GROUP BY id