这篇文章主要介绍了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;
select id,array_to_string(array_agg(name),’,’)
AS NAME_NEW from test
group by 1
ORDER BY 1;
另外:array_agg(distinct(字段名)) 拼接唯一的字段。
一行变多行
select id,regexp_split_to_table(name_new,’,’)
AS NAME from test;
select id,unnest(string_to_array(name_new,’,’))
AS NAME from test;
文章来源:脚本之家
来源地址:https://www.jb51.net/article/204927.htm
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。
发布者:SEO优化专员,转转请注明出处:https://www.chuangxiangniao.com/p/892883.html