在PostgreSQL中,如果你想将一行数据转换为多行,可以使用STRING_AGG()
函数结合WITHIN GROUP (ORDER BY ...)
语句来实现。下面是一个示例:
假设我们有一个名为my_table
的表,其中有一个名为id
的列和一个名为value
的列,我们想要将具有相同id
值的行合并,并将value
列的值用逗号分隔。
SELECT id, STRING_AGG(value, ',') WITHIN GROUP (ORDER BY value) AS values FROM my_table GROUP BY id;
这将返回以下结果:
id | values ----+------------- 1 | value1,value2 2 | value3,value4
在这个例子中,我们首先使用GROUP BY
子句按id
列对数据进行分组。然后,我们使用STRING_AGG()
函数将每个分组中的value
列的值连接成一个字符串,用逗号分隔。最后,我们使用WITHIN GROUP (ORDER BY value)
对结果进行排序。