PostgreSQL對數組的遍曆

來源:互聯網
上載者:User

  PostgreSQL 提供了數群組類型。我來示範下如何具體使用。
建立一個有數群組類型欄位的表。

?
1 2 3 4 5 6 7 8 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]]]);   為了能直觀的看到結果集,我們得把數組的值換成普通的類型拿出來, 有以下幾種方法。
?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 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

帶分區的遍曆: 

?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 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_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

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
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.