PostgreSQL 對數(shù)組的遍歷操作
PostgreSQL 提供了數(shù)組類型。
我來演示下如何具體使用
創(chuàng)建一個(gè)有數(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]]]);
為了能直觀的看到結(jié)果集,我們得把數(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 行記錄) 時(shí)間: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 行記錄) 時(shí)間:20.139 ms
還有就是系統(tǒng)系統(tǒng)了幾個(gè)函數(shù),直接進(jìn)行遍歷,
比如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 行記錄) 時(shí)間: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 行記錄) 時(shí)間:0.850 ms
補(bǔ)充: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
輸出結(jié)果:

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章
PostgreSQL數(shù)據(jù)庫管理系統(tǒng)快速入門
這篇文章主要介紹了PostgreSQL數(shù)據(jù)庫快速入門,PostgreSQL是一個(gè)功能強(qiáng)大的開源對象關(guān)系型數(shù)據(jù)庫系統(tǒng),他使用和擴(kuò)展了SQL語言,并結(jié)合了許多安全存儲和擴(kuò)展最復(fù)雜數(shù)據(jù)工作負(fù)載的功能,需要的朋友可以參考下2023-07-07
解決sqoop從postgresql拉數(shù)據(jù),報(bào)錯(cuò)TCP/IP連接的問題
這篇文章主要介紹了解決sqoop從postgresql拉數(shù)據(jù),報(bào)錯(cuò)TCP/IP連接的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-12-12
PGSQL 實(shí)現(xiàn)把字符串轉(zhuǎn)換成double類型(to_number())
這篇文章主要介紹了PGSQL 實(shí)現(xiàn)把字符串轉(zhuǎn)換成double類型(to_number()),具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-12-12
PostgreSQL使用JSONB存儲和查詢復(fù)雜的數(shù)據(jù)結(jié)構(gòu)
在PostgreSQL中,JSONB是一種二進(jìn)制格式的JSON數(shù)據(jù)類型,它允許你在數(shù)據(jù)庫中存儲和查詢復(fù)雜的JSON數(shù)據(jù)結(jié)構(gòu),本文給大家介紹了如何使用JSONB類型在PostgreSQL中存儲和查詢復(fù)雜的數(shù)據(jù)結(jié)構(gòu),需要的朋友可以參考下2024-04-04
PostgreSQL 更新視圖腳本的注意事項(xiàng)說明
這篇文章主要介紹了PostgreSQL 更新視圖腳本的注意事項(xiàng)說明,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01
pg中replace和translate的用法說明(數(shù)據(jù)少的中文排序)
這篇文章主要介紹了pg中replace和translate的用法說明(數(shù)據(jù)少的中文排序),具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01

