好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > postgresql 實現字符串分割字段轉列表查詢

postgresql 實現字符串分割字段轉列表查詢

熱門標簽:電銷機器人能補救房產中介嗎 電話機器人怎么換人工座席 濟南外呼網絡電話線路 400電話申請客服 地圖標注要花多少錢 移動外呼系統模擬題 天津開發區地圖標注app 廣州電銷機器人公司招聘 江蘇400電話辦理官方

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

如:

假設現在要關聯查詢關于 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沒有問題,接下來就是一起關聯查詢了

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

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表的數據中某些字段做未拼接的形式存在,也就是說 現在要查出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發','#0123456789' ,'#') from dual

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

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

結果:3268;

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

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

比如比較123 和132;

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

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

您可能感興趣的文章:
  • PostgreSQL 查看表的主外鍵等約束關系詳解
  • PostgreSQL中enable、disable和validate外鍵約束的實例
  • postgresql 查詢集合結果用逗號分隔返回字符串處理的操作
  • postgresql數據庫連接數和狀態查詢操作
  • postgresql查詢自動將大寫的名稱轉換為小寫的案例
  • postgresql數據庫使用說明_實現時間范圍查詢
  • Postgresql 查詢表引用或被引用的外鍵操作

標簽:海西 濮陽 辛集 杭州 榆林 昭通 溫州 寶雞

巨人網絡通訊聲明:本文標題《postgresql 實現字符串分割字段轉列表查詢》,本文關鍵詞  postgresql,實現,字符串,分割,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《postgresql 實現字符串分割字段轉列表查詢》相關的同類信息!
  • 本頁收集關于postgresql 實現字符串分割字段轉列表查詢的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 女人被添荫蒂舒服了A片看| japanxxxxhd奶水| 黑人做受69???高潮A片| 亚洲中文字幕久久综合精品| 久久99精品久久久久久综合| 直男叫床18xvideos| 亚洲区小说区| 伊人久久精品中文字幕内容| 红桃精品??国产精品| 成人18免费| 医生检查玩弄潮喷奶头| 三片在线观看| 动漫美女扒开内裤打屁股| 穆桂英含精肉臀迎合娇吟电影| 亚洲 欧美 国产 综合首页 | 女人张开腿日出白浆视频| 婬乱的护士HD在线观看 | 国产人碰人摸人爱免费视频| 快穿特殊调教道具h高辣| 亚洲AV秘?无码一区明步| 亚洲AV秘?精品久久人与人性| 国产大学生露脸激情| 日韩欧美一卡二区| 草草久久久亚洲AV成人片| 四虎精品不卡一区AV视频| 7o岁老太bbw| a亚洲视频| 玩弄花核| 中国XXXXXL免费| 巜妻子的同学波多野结衣聚会3| 禁漫画天堂?a漫入口| 激情偷拍网| 日本奶水大岛优香| 国产精自产拍久久久久久| 精产嫩模国品一二三区| 啊灬啊灬啊灬快灬深用力嘿嘿最新章节| 欧美超乳videos超清720| 把朕c烂都可以| 在线综合亚洲欧美自拍| 麻花影视永久免费观看| 亚洲成a人v欧美综合天堂软件|