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

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

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

在數(shù)據(jù)查詢中,有一張a表存有另一張b表的id并以‘,'隔開(kāi)

如:

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

分割查詢:字符串轉(zhuǎn)列表函數(shù) :regexp_split_to_table()

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

查詢后,字符串就變成了列表,然后你就可以根據(jù)這個(gè)列表去找b表的相關(guān)信息了。

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 ), ','))

首先數(shù)據(jù)驗(yàn)證是正確的,說(shuō)明sql沒(méi)有問(wèn)題,接下來(lái)就是一起關(guān)聯(lián)查詢了

1.因?yàn)檫@個(gè)a表與b表是一對(duì)多的關(guān)系,所以我們先關(guān)聯(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表的數(shù)據(jù),b表的數(shù)據(jù)中某些字段做未拼接的形式存在,也就是說(shuō) 現(xiàn)在要查出a表的數(shù)據(jù)

 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

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

補(bǔ)充:pgsql 查詢字段中根據(jù)逗號(hào)分隔的字符串的的 個(gè)數(shù)

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

參見(jiàn):

1.translate 與replace類似是替換函數(shù),但translate是一次替換多個(gè)單個(gè)的字符。

2.基本用法,字符對(duì)應(yīng)替換。

例子:

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

結(jié)果:abc4567 。

3.如果 沒(méi)有對(duì)應(yīng)字符則替換為null;

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

結(jié)果:ab4567.

4.如果對(duì)應(yīng)字符過(guò)多,不影響

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

結(jié)果:abc4567

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

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

結(jié)果:null;

6.如果想篩掉對(duì)應(yīng)字符,應(yīng)傳入一個(gè)不相關(guān)字符,同時(shí)替換字符也加一個(gè)相同字符;

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

結(jié)果:4567;

7.如果相同字符對(duì)應(yīng)多個(gè)字符,按第一個(gè);

select translate('12334567','1233' ,‘a(chǎn)bcd') from dual;

結(jié)果:abcc4567;

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

先把數(shù)字篩選掉,

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

再用篩選出的漢字去篩選原來(lái)的語(yǔ)句留下數(shù)字,

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

結(jié)果:3268;

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

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

比如比較123 和132;

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

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。

相關(guān)文章

  • PostgreSQL物理備份恢復(fù)之 pg_rman的用法說(shuō)明

    PostgreSQL物理備份恢復(fù)之 pg_rman的用法說(shuō)明

    這篇文章主要介紹了PostgreSQL物理備份恢復(fù)之 pg_rman的用法說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-02-02
  • PostgreSQL教程(八):索引詳解

    PostgreSQL教程(八):索引詳解

    這篇文章主要介紹了PostgreSQL教程(八):索引詳解,本文講解了索引的類型、復(fù)合索引、組合多個(gè)索引、唯一索引、表達(dá)式索引、部分索引等內(nèi)容,需要的朋友可以參考下
    2015-05-05
  • 詳解如何在Ubuntu?18.04上安裝和使用PostgreSQL

    詳解如何在Ubuntu?18.04上安裝和使用PostgreSQL

    關(guān)系數(shù)據(jù)庫(kù)管理系統(tǒng)是許多網(wǎng)站和應(yīng)用程序的關(guān)鍵組件,它們提供了一種結(jié)構(gòu)化的方式來(lái)存儲(chǔ)、組織和訪問(wèn)信息,本文演示了如何在?Ubuntu?18.04?VPS?實(shí)例上安裝?Postgres,并提供了基本數(shù)據(jù)庫(kù)管理的說(shuō)明,需要的朋友可以參考下
    2024-07-07
  • PostgreSQL存儲(chǔ)過(guò)程用法實(shí)戰(zhàn)詳解

    PostgreSQL存儲(chǔ)過(guò)程用法實(shí)戰(zhàn)詳解

    這篇文章主要介紹了PostgreSQL存儲(chǔ)過(guò)程用法,結(jié)合具體實(shí)例詳細(xì)分析了PostgreSQL數(shù)據(jù)庫(kù)存儲(chǔ)過(guò)程的定義、使用方法及相關(guān)操作注意事項(xiàng),并附帶一個(gè)完整實(shí)例供大家參考,需要的朋友可以參考下
    2018-08-08
  • PostgreSQL:string_agg?多列值聚合成一列的操作示例

    PostgreSQL:string_agg?多列值聚合成一列的操作示例

    PostgreSQL中的STRING_AGG()函數(shù)是一個(gè)聚合函數(shù),用于連接字符串列表并在字符串之間放置分隔符,這篇文章主要介紹了PostgreSQL:string_agg多列值聚合成一列,需要的朋友可以參考下
    2023-08-08
  • postgresql兼容MySQL on update current_timestamp問(wèn)題

    postgresql兼容MySQL on update current_timestamp

    這篇文章主要介紹了postgresql兼容MySQL on update current_timestamp問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • PostgreSQL查找并刪除重復(fù)數(shù)據(jù)的方法總結(jié)

    PostgreSQL查找并刪除重復(fù)數(shù)據(jù)的方法總結(jié)

    這篇文章主要給大家介紹了PostgreSQL查找并刪除重復(fù)數(shù)據(jù)的方法,文章通過(guò)代碼示例介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一點(diǎn)的幫助,需要的朋友可以參考下
    2023-10-10
  • postgresql初始化之initdb的使用詳解

    postgresql初始化之initdb的使用詳解

    這篇文章主要介紹了postgresql初始化之initdb的使用詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-01-01
  • Cenots7 離線安裝部署PostgreSQL 的詳細(xì)過(guò)程

    Cenots7 離線安裝部署PostgreSQL 的詳細(xì)過(guò)程

    這篇文章主要介紹了Cenots7 離線安裝部署PostgreSQL 的詳細(xì)過(guò)程,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-10-10
  • postgresql限制某個(gè)用戶僅連接某一個(gè)數(shù)據(jù)庫(kù)的操作

    postgresql限制某個(gè)用戶僅連接某一個(gè)數(shù)據(jù)庫(kù)的操作

    這篇文章主要介紹了postgresql限制某個(gè)用戶僅連接某一個(gè)數(shù)據(jù)庫(kù)的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-01-01

最新評(píng)論