好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > PostgreSQL 對數組的遍歷操作

PostgreSQL 對數組的遍歷操作

熱門標簽:移動外呼系統模擬題 電話機器人怎么換人工座席 濟南外呼網絡電話線路 400電話申請客服 江蘇400電話辦理官方 天津開發區地圖標注app 廣州電銷機器人公司招聘 地圖標注要花多少錢 電銷機器人能補救房產中介嗎

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' carport
FROM
 (
 SELECT
 orderno,
 fromno,
 fromamount,
 json_array_elements (fromlotno) fromlotno,
 json_array_elements (othercondition) othercondition
 FROM
 t_feather_source
 ) A

輸出結果:

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • 解決postgresql表中的字段名稱包含特殊符號的問題
  • postgresql數據庫使用說明_實現時間范圍查詢
  • postgresql 實現將數組變為行
  • PostgreSQL存儲過程循環調用方式
  • postgresql 存儲函數調用變量的3種方法小結
  • postgresql~*符號的含義及用法說明

標簽:濮陽 杭州 寶雞 海西 榆林 溫州 辛集 昭通

巨人網絡通訊聲明:本文標題《PostgreSQL 對數組的遍歷操作》,本文關鍵詞  PostgreSQL,對,數組,的,遍歷,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PostgreSQL 對數組的遍歷操作》相關的同類信息!
  • 本頁收集關于PostgreSQL 對數組的遍歷操作的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 老板好大好爽我要喷水了| 无码av日本一区二区免费| 日韩人妻第一页| 男妓跪趴撅着女人| 欧美日韩国产亚洲人成| 手机看片片| 3p娇妻在客厅被弄到高潮| 三妻四妾高清完整版电影免费观看| 亚洲一级毛片免费看| 人乳喂奶电影bd手机在线观看| 夜色88V精品国产亚洲AV小说| 人妻熟女一区二区AⅤ佐佐木明希| 国产麻豆剧传媒精品国产AV| 亚洲娇小被黑人巨大撑爆小说| brazzershd欧美最新版| 宋茜三级未删减版| 免费播放婬乱婬视频国产| 久久偷窥视频| yy6080成人午夜理论电影| 公交车上伦流澡到高潮Hnp电影| 丰满美妇岳叫我吸她大乳| 性欧美videofreel另类| 埋头吸允蜜汁h| 91风吟鸟唱精品系列嫩模| 国产精品国产自产拍高清AV| 欧美同志gaypronvideos| 大乳妇女bd完整版| 99国产精品久久久久99打野战| h男男| 国产一级婬片A片AA片| 杂烩大乱炖目录| 国产无限制自拍| 野外做受又粗又硬又大| 老师别揉我胸啊嗯上课呢视频 | 久热这里只有精品视频在线| 用精油按摩达到高淖潮| 精品国产乱码久久久久久88AV | 欧美亚洲国产成人高清在线| 2023男人天堂| 伊人精品视频在线| x8x8免费网站|