欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

postgresql 實現(xiàn)字符串分割字段轉列表查詢

 更新時間:2021年02月01日 10:04:20   作者:dbsjack  
這篇文章主要介紹了postgresql 實現(xiàn)字符串分割字段轉列表查詢,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

在數據查詢中,有一張a表存有另一張b表的id并以‘,'隔開

如:

假設現(xiàn)在要關聯(lián)查詢關于 b表的一些信息,怎么辦。

分割查詢:字符串轉列表函數 :regexp_split_to_table()

select * from regexp_split_to_table ((select product_ids from fee_project_meal where id = 116199376233182210 ), ',')

查詢后,字符串就變成了列表,然后你就可以根據這個列表去找b表的相關信息了。

select *
from pm.product 
where id::text in 
(select * from regexp_split_to_table ((select product_ids from bp.fee_project_meal where id = 116199376233182210 ), ','))

首先數據驗證是正確的,說明sql沒有問題,接下來就是一起關聯(lián)查詢了

1.因為這個a表與b表是一對多的關系,所以我們先關聯(lián)出多條。

select a.id as "a表_id",
a.name as "a表_name",
p.name as "b表_name"
from bp.fee_project_meal a
LEFT JOIN pm.product p on p.id::text 
in (select * from regexp_split_to_table ((select product_ids from bp.fee_project_meal where id = a.id ), ','))
where a.id = 116199376233182210

2.還有一種就是 我只要查出a表的數據,b表的數據中某些字段做未拼接的形式存在,也就是說 現(xiàn)在要查出a表的數據

 SELECT
 a.id as "a表_id",
  a.name as "a表_name",
  bb.p_id as "b表_拼接id",
  bb.p_name as "b表_拼接name"
 from bp.fee_project_meal a
  left join (
select a.id as "bb_id",String_agg(p.id::text,',') as "p_id",String_agg(p.name::text,',') as "p_name"
from bp.fee_project_meal a
LEFT JOIN pm.product p on 
p.id::text in (select * from regexp_split_to_table ((select product_ids from bp.fee_project_meal where id = a.id ), ','))
GROUP BY 1
) bb on bb."bb_id" = a.id

以上就是,字符串字段的拆解查詢。

補充:pgsql 查詢字段中根據逗號分隔的字符串的的 個數

select length(translate(column,','||column,','))+1 from table

參見:

1.translate 與replace類似是替換函數,但translate是一次替換多個單個的字符。

2.基本用法,字符對應替換。

例子:

select translate('1234567','123' ,'abc') from dual ;--1替換為a,2替換為b,3替換為c

結果:abc4567 。

3.如果 沒有對應字符則替換為null;

select translate('1234567','123' ,'ab') from dual;--3替換為null;

結果:ab4567.

4.如果對應字符過多,不影響

select translate('1234567','123' ,'abccd') from dual;

結果:abc4567

5.如果替換字符整個為空字符 ,則直接返回null

select translate('1234567','123' ,'') from dual;

結果:null;

6.如果想篩掉對應字符,應傳入一個不相關字符,同時替換字符也加一個相同字符;

select translate('1234567','&123' ,'&') from dual;

結果:4567;

7.如果相同字符對應多個字符,按第一個;

select translate('12334567','1233' ,‘abcd') from dual;

結果:abcc4567;

8.如果想保留某些特定字符篩選掉其他的,比如篩掉漢字保留數字

先把數字篩選掉,

select translate('你師看了3三樓2的6開8發(fā)','#0123456789' ,'#') from dual

再用篩選出的漢字去篩選原來的語句留下數字,

select translate('你師看了3三樓2的6開8發(fā)','#'||translate('你師看了3三樓2的6開8發(fā)','#0123456789' ,'#'),'#') from dual;

結果:3268;

9.還有其他靈活用法,比如我可以判斷兩個字符串如果:字符串都是數字字符,然后數字字符的順序不同,且每個字符只出現(xiàn)一次,

我可以判斷他們包含的數字是不是完全一致;

比如比較123 和132;

select 1 from dual where
translate('0123456789','123' ,'aaaaaaaaaa') =translate('0123456789','132' ,'aaaaaaaaaa')

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

相關文章

  • 關于PostgreSQL錯誤日志與慢查詢日志收集

    關于PostgreSQL錯誤日志與慢查詢日志收集

    這篇文章主要介紹了關于PostgreSQL錯誤日志與慢查詢日志收集,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • Windows版?PostgreSQL?利用?pg_upgrade?進行大版升級操作方法

    Windows版?PostgreSQL?利用?pg_upgrade?進行大版升級操作方法

    最近?PostgreSQL?15?版本正式發(fā)布了,新版本的各種特性和好處本文就不展開介紹了,主要介紹一下?Windows?環(huán)境下?PostgreSQL?大版本升級的方法,我們現(xiàn)在的幾個數據庫都是運行在?Windows服務器的?PostgreSQL?14,需要的朋友可以參考下
    2022-10-10
  • Postgresql 數據庫權限功能的使用總結

    Postgresql 數據庫權限功能的使用總結

    這篇文章主要介紹了Postgresql 數據庫權限功能的使用總結,具有很好的參考價值,對大家有所幫助。一起跟隨小編過來看看吧
    2021-02-02
  • postgresql 中position函數的性能詳解

    postgresql 中position函數的性能詳解

    這篇文章主要介紹了postgresql 中position函數的性能詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-02-02
  • PostgreSQL教程(七):函數和操作符詳解(3)

    PostgreSQL教程(七):函數和操作符詳解(3)

    這篇文章主要介紹了PostgreSQL教程(七):函數和操作符詳解(3),本文講解了序列操作函數、條件表達式、數組函數和操作符、系統(tǒng)信息函數、系統(tǒng)管理函數等內容,需要的朋友可以參考下
    2015-05-05
  • postgresql 中的幾個 timeout參數 用法說明

    postgresql 中的幾個 timeout參數 用法說明

    這篇文章主要介紹了postgresql中的幾個timeout參數用法說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • 詳解如何定位postgreSQL數據庫中未被使用過的索引

    詳解如何定位postgreSQL數據庫中未被使用過的索引

    在生產環(huán)境上,由于不規(guī)范的優(yōu)化措施,數據庫中可能存在大量的索引,并且相當一部分的索引重未被使用過,今天帶大家如何找出這些索引,本文給大家介紹了定位postgreSQL數據庫中未被使用過的索引的方法,需要的朋友可以參考下
    2024-03-03
  • Postgresql數據庫密碼忘記的詳細解決方法

    Postgresql數據庫密碼忘記的詳細解決方法

    在使用PostgreSQL數據庫時,忘記數據庫密碼可能會影響到正常的開發(fā)和維護工作,這篇文章主要介紹了Postgresql數據庫密碼忘記的詳細解決方法,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2025-06-06
  • PostgreSql從庫重新配置的詳情

    PostgreSql從庫重新配置的詳情

    這篇文章主要介紹了PostgreSql從庫重新配置的詳情,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-12-12
  • postgresql查詢今天、昨天、本周、本月、上月、今年、去年的時間以及計算時間之差

    postgresql查詢今天、昨天、本周、本月、上月、今年、去年的時間以及計算時間之差

    PostgreSQL提供了許多返回當前日期和時間的函數,下面這篇文章主要給大家介紹了關于postgresql查詢今天、昨天、本周、本月、上月、今年、去年的時間以及計算時間之差的相關資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2024-08-08

最新評論