91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在PostgreSQL中對數組進行遍歷

發布時間:2021-01-28 11:43:42 來源:億速云 閱讀:621 作者:Leah 欄目:開發技術

本篇文章給大家分享的是有關怎么在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

怎么在PostgreSQL中對數組進行遍歷

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中對數組進行遍歷

以上就是怎么在PostgreSQL中對數組進行遍歷,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

新余市| 象山县| 太康县| 合肥市| 台山市| 永州市| 泗阳县| 山东| 郴州市| 井研县| 双牌县| 聂拉木县| 肇州县| 白水县| 霍林郭勒市| 云林县| 宁武县| 新郑市| 荣成市| 临桂县| 沭阳县| 台州市| 宝山区| 穆棱市| 城步| 攀枝花市| 台东市| 璧山县| 奉化市| 阿合奇县| 芷江| 龙岩市| 忻州市| 澄城县| 鸡西市| 楚雄市| 榆社县| 洱源县| 白山市| 瓮安县| 鄂尔多斯市|