解決PostgreSQL Array使用中的一些小問題
在PostgreSQL 中可以使用Array數(shù)據(jù)結(jié)構(gòu),例如
select array[1,2,3]; return {1,2,3}
但是,如果
select array[1,2,3][1]; --會報錯 select (select array[1,2,3])[1] --可以使用
那么在用正則匹配函數(shù) regexp_match 就會遇到這樣的問題,如
select regexp_match('123-123', '(\d+)-(\d+)'); --return {123, 123} select regexp_match('123-123', '(\d+)-(\d+)')[1]; --報錯
但是,如果你想獲取其中一個元素,你就得使用嵌套查詢,如
select(select regexp_match('123-123', '(\d+)-(\d+)'))[1]; --return 123
其次,你如果要用regexp_matches 加上全局搜索,可能會生成多行數(shù)據(jù),如
select 'a', array(select regexp_matches('aa-aa', '(aa)+', 'g')); -- return 2 rows a {aa} a {aa}
合并為一行,需要array函數(shù)
select 'a', array(select regexp_matches('aa-aa', '(aa)+', 'g')); --return a {{aa},{aa}}
取其中的元素
select a, b[1][1] from (select 'a' as a, array(select regexp_matches('aa-aa', '(aa)+', 'g')) as b) as c; --return aa
補充:PostgreSQL的 array_to_string 功能
開始
用 第二個參數(shù)連接數(shù)組元素,例:
postgres=# select array_to_string (ARRAY[1,2,3],'##'); array_to_string ----------------- 1##2##3 (1 row) postgres=#
結(jié)束~
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章
PostgreSQL樹形結(jié)構(gòu)的遞歸查詢示例
這篇文章主要給大家介紹了關(guān)于PostgreSQL樹形結(jié)構(gòu)的遞歸查詢的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用PostgreSQL具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧2019-05-05PostgreSQL實現(xiàn)按年、月、日、周、時、分、秒的分組統(tǒng)計
這篇文章介紹了PostgreSQL實現(xiàn)按年、月、日、周、時、分、秒分組統(tǒng)計的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-06-06postgresql 中position函數(shù)的性能詳解
這篇文章主要介紹了postgresql 中position函數(shù)的性能詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-02-02PostgreSQL時間線(timeline)和History File的用法
這篇文章主要介紹了PostgreSQL時間線(timeline)和History File的用法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-12-12PostgreSQL基礎(chǔ)知識之SQL操作符實踐指南
這篇文章主要給大家介紹了關(guān)于PostgreSQL基礎(chǔ)知識之SQL操作符實踐的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用PostgreSQL具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧2020-05-05PostgreSQL查詢和處理JSON數(shù)據(jù)
這篇文章主要給大家介紹了關(guān)于PostgreSQL查詢和處理JSON數(shù)據(jù)的相關(guān)資料,需要的朋友可以參考下2023-11-11