PostgreSQL 提供了數(shù)組類型。
我來演示下如何具體使用
創(chuàng)建一個有數(shù)組類型字段的表。
create table test_array(id serial primary key, str1 int[][][]);
插入兩條測試數(shù)據(jù)。
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]]]);
為了能直觀的看到結果集,我們得把數(shù)組的值換成普通的類型拿出來, 有以下幾種方法。
不帶分片的遍歷,
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
還有就是系統(tǒng)系統(tǒng)了幾個函數(shù),直接進行遍歷,
比如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
![](/d/20211018/3151976ea8eb5ad638cb8612399f05d9.gif)
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
輸出結果:
![](/d/20211018/c030b3016c302015b5f117524fb1d25a.gif)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。
您可能感興趣的文章:- 解決postgresql表中的字段名稱包含特殊符號的問題
- postgresql數(shù)據(jù)庫使用說明_實現(xiàn)時間范圍查詢
- postgresql 實現(xiàn)將數(shù)組變?yōu)樾?/li>
- PostgreSQL存儲過程循環(huán)調(diào)用方式
- postgresql 存儲函數(shù)調(diào)用變量的3種方法小結
- postgresql~*符號的含義及用法說明