有的時候需要把數組元素同表中的字段進行關系運算,首先得把array變?yōu)橛涗浶?/p>
SELECT "unnest"(array[1,2,3])
結果:
unnest
求數組交集:
SELECT "unnest"(array[1,2,3]) INTERSECT SELECT "unnest"(array[3,4,5])
結果:
unnest
3
補充:PostgreSQL單列多行變一行一行變多行
工作中經常遇到這樣一個場景,希望將某個字斷查詢出得結果組合成為一個字符串,用逗號分割(或者分號),通過PG中的函數該如何實現?
多行變一行
實例表:
想要的結果:
方法一:string_agg(字段名,分隔符)
select id,string_agg(name,',') AS NAME_NEW from test
group by 1
ORDER BY 1
方法二:array_agg(字段名)
select id,array_agg(name)
AS NAME_NEW from test
group by 1
ORDER BY 1;
select id,array_to_string(array_agg(name),',')
AS NAME_NEW from test
group by 1
ORDER BY 1;
另外:array_agg(distinct(字段名)) 拼接唯一的字段。
一行變多行
select id,regexp_split_to_table(name_new,',')
AS NAME from test;
select id,unnest(string_to_array(name_new,','))
AS NAME from test;
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。
您可能感興趣的文章:- 淺談PostgreSQL中大小寫不敏感問題
- PostgreSQL LIKE 大小寫實例
- Postgresql 數據庫轉義字符操作
- postgresql~*符號的含義及用法說明
- postgresql數據庫使用說明_實現時間范圍查詢
- 基于PostgreSql 別名區(qū)分大小寫的問題