时间:2021-05-24
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' carportFROM ( SELECT orderno, fromno, fromamount, json_array_elements (fromlotno) fromlotno, json_array_elements (othercondition) othercondition FROM t_feather_source ) A输出结果:
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
For...In声明用于遍历数组或者对象的属性(对数组或者对象的属性进行循环操作)。JavaScriptFor...In声明For...In声明用于对数组或者对
使用for...in可以遍历js对象的属性,用法如下: for...in语句用于遍历数组或者对象的属性(对数组或者对象的属性进行循环操作)。 for..
在PHP编程中,在遍历数组的时候经常需要先计算数组的长度作为循环结束的判断条件,而在PHP里面对数组的操作是很频繁的,因此count也算是一个常用函数,下面研究
对数组的遍历大家最常用的就是for循环,ES5的话也可以使用forEach,ES5具有遍历数组功能的还有map、filter、some、every、reduce
本文实例讲述了php中使用key,value,current,next和prev函数遍历数组的方法。分享给大家供大家参考。具体分析如下:php中针对数组遍历有一