这篇文章主要介绍了postgresql 实现将数组变为行的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧。
有的时候需要把数组元素同表中的字段进行关系运算,首先得把array变为记录行
SELECT "unnest"(array[1,2,3])
结果:
unnest
求数组交集:
SELECT "unnest"(array[1,2,3]) INTERSECT SELECT "unnest"(array[3,4,5])
结果:
unnest
3
补充:PostgreSQL单列多行变一行&一行变多行
工作中经常遇到这样一个场景,希望将某个字断查询出得结果组合成为一个字符串,用逗号分割(或者分号),通过PG中的函数该如何实现?
多行变一行
实例表:
想要的结果:
方法一:string_agg(字段名,分隔符)
select id,string_agg(name,',') AS NAME_NEW from test
group by 1
ORDER BY 1
方法二:array_agg(字段名)
select id,array_agg(name)
AS NAME_NEW from test
group by 1
ORDER BY 1;