婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識(shí)庫(kù) > postgresql 實(shí)現(xiàn)字符串分割字段轉(zhuǎn)列表查詢

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

熱門標(biāo)簽:電銷機(jī)器人能補(bǔ)救房產(chǎn)中介嗎 電話機(jī)器人怎么換人工座席 濟(jì)南外呼網(wǎng)絡(luò)電話線路 400電話申請(qǐng)客服 地圖標(biāo)注要花多少錢 移動(dòng)外呼系統(tǒng)模擬題 天津開發(fā)區(qū)地圖標(biāo)注app 廣州電銷機(jī)器人公司招聘 江蘇400電話辦理官方

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

如:

假設(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)證是正確的,說明sql沒有問題,接下來就是一起關(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ù)中某些字段做未拼接的形式存在,也就是說 現(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

參見:

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.如果 沒有對(duì)應(yīng)字符則替換為null;

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

結(jié)果:ab4567.

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

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開8發(fā)','#0123456789' ,'#') from dual

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

select translate('你師看了3三樓2的6開8發(fā)','#'||translate('你師看了3三樓2的6開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ò)誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • PostgreSQL 查看表的主外鍵等約束關(guān)系詳解
  • PostgreSQL中enable、disable和validate外鍵約束的實(shí)例
  • postgresql 查詢集合結(jié)果用逗號(hào)分隔返回字符串處理的操作
  • postgresql數(shù)據(jù)庫(kù)連接數(shù)和狀態(tài)查詢操作
  • postgresql查詢自動(dòng)將大寫的名稱轉(zhuǎn)換為小寫的案例
  • postgresql數(shù)據(jù)庫(kù)使用說明_實(shí)現(xiàn)時(shí)間范圍查詢
  • Postgresql 查詢表引用或被引用的外鍵操作

標(biāo)簽:海西 濮陽 辛集 杭州 榆林 昭通 溫州 寶雞

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《postgresql 實(shí)現(xiàn)字符串分割字段轉(zhuǎn)列表查詢》,本文關(guān)鍵詞  postgresql,實(shí)現(xiàn),字符串,分割,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《postgresql 實(shí)現(xiàn)字符串分割字段轉(zhuǎn)列表查詢》相關(guān)的同類信息!
  • 本頁收集關(guān)于postgresql 實(shí)現(xiàn)字符串分割字段轉(zhuǎn)列表查詢的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 五莲县| 中方县| 图片| 离岛区| 嘉禾县| 荣昌县| 临泽县| 清水河县| 得荣县| 玉环县| 茌平县| 会昌县| 沾益县| 天门市| 忻城县| 鹿泉市| 河源市| 太康县| 泽州县| 永宁县| 郯城县| 磴口县| 山丹县| 赤壁市| 大连市| 吉首市| 醴陵市| 新丰县| 和平县| 龙江县| 樟树市| 北海市| 蒙自县| 舟曲县| 咸阳市| 红桥区| 杭州市| 五家渠市| 青州市| 米易县| 佛山市|