Postgresql 截取字符串的案例
截取字符串一般用 substring 就夠用了。對于有些長度不定的就沒法用這個函數了,但還是有規(guī)律的,可以某個字符分割。
如:(這是一個url,截取最后一部分。現(xiàn)在要取 - 后面部分內容)
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"
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。
相關文章
淺析postgresql 數據庫 TimescaleDB 修改分區(qū)時間范圍
這篇文章主要介紹了淺析postgresql 數據庫 TimescaleDB 修改分區(qū)時間范圍,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-01-01
PostgreSQL實時查看數據庫實例正在執(zhí)行的SQL語句實例詳解
在任何數據庫中,分析和優(yōu)化SQL的執(zhí)行,最重要的工作就是執(zhí)行計劃的解讀,而說到執(zhí)行計劃得先了解postgresql的查詢執(zhí)行過程,下面這篇文章主要給大家介紹了關于PostgreSQL實時查看數據庫實例正在執(zhí)行的SQL語句的相關資料,需要的朋友可以參考下2023-01-01
postgresql數據庫設置id自增的基本方法舉例例子解析
這篇文章主要給大家介紹了關于postgresql數據庫設置id自增的基本方法舉例,文章介紹了在PostgreSQL中實現(xiàn)自增ID的兩種方法,分別是使用序列和觸發(fā)器,序列方法簡單直接,而觸發(fā)器和函數方法則提供了更大的靈活性,需要的朋友可以參考下2024-11-11
postgresql關于like%xxx%的優(yōu)化操作
這篇文章主要介紹了postgresql關于like%xxx%的優(yōu)化操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01

