佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > PostgreSQL 對數(shù)組的遍歷操作

PostgreSQL 對數(shù)組的遍歷操作

熱門標簽:Linux服務器 地方門戶網(wǎng)站 AI電銷 百度競價排名 網(wǎng)站排名優(yōu)化 服務外包 鐵路電話系統(tǒng) 呼叫中心市場需求

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]]]);

為了能直觀的看到結(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 行記錄) 
 
時間: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

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é)果:

以上為個人經(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種方法小結(jié)
  • postgresql~*符號的含義及用法說明

標簽:黃山 銅川 湖南 仙桃 湘潭 崇左 蘭州 衡水

巨人網(wǎng)絡通訊聲明:本文標題《PostgreSQL 對數(shù)組的遍歷操作》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    荣成市| 敦煌市| 九龙县| 昔阳县| 石门县| 昭平县| 开远市| 阳东县| 大新县| 黑河市| 秦安县| 天门市| 区。| 德清县| 华坪县| 额尔古纳市| 米脂县| 买车| 明光市| 桃江县| 新疆| 贵溪市| 西林县| 牟定县| 正定县| 苍南县| 巴彦县| 密山市| 岫岩| 灵寿县| 泸水县| 万盛区| 赣州市| 黄骅市| 乌兰县| 新郑市| 台东市| 咸丰县| 定西市| 河间市| 晋江市|