Postgresql 截取字符串的案例

截取字符串一般用 substring 就夠用瞭。對於有些長度不定的就沒法用這個函數瞭,但還是有規律的,可以某個字符分割。

如:(這是一個url,截取最後一部分。現在要取 – 後面部分內容)

8a59e88177ad5e70-20170317120301AB9E.plist
12b8d5c26d83a17f-20170308173008D5DD.plist

這時需要 split_part 函數,如:

— url 一共3個 – ,字符串被分成4部分,取最後一部分,那最後一個參數就是4

select split_part(fs.cdn_url ,'-', 4) from file_store fs 

如果 分割符 數量不一樣怎麼辦,這裡就要計算分割符的數量瞭

— 將 1個分隔符 替換為 2個分隔符,然後用長度相減得到分隔符數

— 最後 +1 是為瞭取最後一部分內容

select split_part(fs.cdn_url ,'-', length(replace(fs.cdn_url,'-','--')) - length(fs.cdn_url) + 1) from file_store fs 

補充:PostgreSQL字符串截取替換

初始化數據庫

CREATE TABLE public.t1
(
 name text
)
 name
-------
"David"
"Peter"
"任務2016-09-10 10:09:00"
"任務2016-10-10 12:03:00"
"任務2016-12-22 14:10:00"

把包含”任務”的記錄替換為”Job”

update t1 set name= 'Job'||substring(name,3) where substring(name,position('任務' in name),2)='任務'; 
select * from t1;
 name
-------
"David"
"Peter"
"Job2016-09-10 10:09:00"
"Job2016-10-10 12:03:00"
"Job2016-12-22 14:10:00"

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