天天看點

postgresql 周遊參數_【原創】PostgreSQL 對數組的周遊

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

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

<> foreach x slice 1 in array array1

loop

nlen := array_length(x,1);

i := 1;

<> 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