postgresql 完成将数组变为行

这篇文章主要介绍了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;
【声明】:芜湖站长网内容转载自互联网,其相关言论仅代表作者个人观点绝非权威,不代表本站立场。如您发现内容存在版权问题,请提交相关链接至邮箱:bqsm@foxmail.com,我们将及时予以处理。

相关文章