本篇文章给大家分享的是有关怎么在PostgreSQL中对数组进行遍历,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。
创建一个有数组类型字段的表。
create table test_array(id serial primary key, str1 int[][][]);
插入两条测试数据。
insert into test_array values (1,array[[[1,2],[3,4],[5,6]],[[20,30],[40,50],[70,100]]]); insert into test_array values (2,array[[[100,200],[300,400],[500,600]],[[2000,3000],[4000,5000],[7000,10000]]]);
为了能直观的看到结果集,我们得把数组的值换成普通的类型拿出来, 有以下几种方法。
不带分片的遍历,
create or replace function sp_array2table_simple( anyarray ) returns table (element int) as $ytt$ declare array1 alias for $1; x int; begin drop table if exists tmp_1; create temporary table tmp_1 (id int); <<label1>> foreach x in array array1 loop insert into tmp_1 values (x); end loop label1; return query select * from tmp_1; end; $ytt$ language plpgsql; t_girl=#select sp_array2table_simple(str1) as array_list from test_array where id = 2; array_list ------------ 100 200 300 400 500 600 2000 3000 4000 5000 7000 10000 (12 行记录) 时间:7.780 ms
带分片的遍历:
create or replace function sp_array2table( anyarray ) returns table (element int) as $ytt$ declare array1 alias for $1; x int[]; nlen int := 0; i int := 1; begin drop table if exists tmp_1; create temporary table tmp_1 (id int); <<label1>> foreach x slice 1 in array array1 loop nlen := array_length(x,1); i := 1; <<label2>> while i <= nlen loop insert into tmp_1 values (x[i]); i := i + 1; end loop label2; end loop label1; return query select * from tmp_1; end; $ytt$ language plpgsql; t_girl=#select sp_array2table(str1) as array_list from test_array where id = 2; array_list ------------ 100 200 300 400 500 600 2000 3000 4000 5000 7000 10000 (12 行记录) 时间:20.139 ms
还有就是系统系统了几个函数,直接进行遍历,
比如unnest
t_girl=#select unnest(str1) as array_list from test_array where id = 2; array_list ------------ 100 200 300 400 500 600 2000 3000 4000 5000 7000 10000 (12 行记录) 时间:1.002 ms
比如array_to_string 等。
t_girl=#select regexp_split_to_table(array_to_string(str1,','),',+') as array_list from test_array where id = 2; array_list ------------ 100 200 300 400 500 600 2000 3000 4000 5000 7000 10000 (12 行记录) 时间:0.850 ms
补充:PostgreSQL遍历Json
SQL:
SELECT orderno, fromno, fromamount, fromlotno ->> 'index' fromlotno, othercondition ->> 'supplicode' supplicode, othercondition ->> 'downcode' downcode, othercondition ->> 'spec' spec, othercondition ->> 'carport' carport FROM ( SELECT orderno, fromno, fromamount, json_array_elements (fromlotno) fromlotno, json_array_elements (othercondition) othercondition FROM t_feather_source ) A
输出结果:
以上就是怎么在PostgreSQL中对数组进行遍历,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注亿速云行业资讯频道。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。