Postgresql 截取字符串的案例
截取字符串一般用 substring 就夠用了。對于有些長度不定的就沒法用這個(gè)函數(shù)了,但還是有規(guī)律的,可以某個(gè)字符分割。
如:(這是一個(gè)url,截取最后一部分。現(xiàn)在要取 - 后面部分內(nèi)容)
8a59e88177ad5e70-20170317120301AB9E.plist 12b8d5c26d83a17f-20170308173008D5DD.plist
這時(shí)需要 split_part 函數(shù),如:
-- url 一共3個(gè) - ,字符串被分成4部分,取最后一部分,那最后一個(gè)參數(shù)就是4
select split_part(fs.cdn_url ,'-', 4) from file_store fs
如果 分割符 數(shù)量不一樣怎么辦,這里就要計(jì)算分割符的數(shù)量了
-- 將 1個(gè)分隔符 替換為 2個(gè)分隔符,然后用長度相減得到分隔符數(shù)
-- 最后 +1 是為了取最后一部分內(nèi)容
select split_part(fs.cdn_url ,'-', length(replace(fs.cdn_url,'-','--')) - length(fs.cdn_url) + 1) from file_store fs
補(bǔ)充:PostgreSQL字符串截取替換
初始化數(shù)據(jù)庫
CREATE TABLE public.t1 ( name text ) name ------- "David" "Peter" "任務(wù)2016-09-10 10:09:00" "任務(wù)2016-10-10 12:03:00" "任務(wù)2016-12-22 14:10:00"
把包含"任務(wù)"的記錄替換為"Job"
update t1 set name= 'Job'||substring(name,3) where substring(name,position('任務(wù)' in name),2)='任務(wù)'; select * from t1; name ------- "David" "Peter" "Job2016-09-10 10:09:00" "Job2016-10-10 12:03:00" "Job2016-12-22 14:10:00"
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章
postgresql 循環(huán)函數(shù)的簡單實(shí)現(xiàn)操作
這篇文章主要介紹了postgresql 循環(huán)函數(shù)的簡單實(shí)現(xiàn)操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01PostgreSQL查詢和處理JSON數(shù)據(jù)
這篇文章主要給大家介紹了關(guān)于PostgreSQL查詢和處理JSON數(shù)據(jù)的相關(guān)資料,需要的朋友可以參考下2023-11-11Postgresql 檢查數(shù)據(jù)庫主從復(fù)制進(jìn)度的操作
這篇文章主要介紹了Postgresql 檢查數(shù)據(jù)庫主從復(fù)制進(jìn)度的操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-12-12基于PostgreSQL的時(shí)序數(shù)據(jù)庫TimescaleDB的基本用法和概念
時(shí)序數(shù)據(jù)是指按照時(shí)間順序存儲的數(shù)據(jù),TimescaleDB是一個(gè)開源的、擴(kuò)展了PostgreSQL的時(shí)序數(shù)據(jù)庫擴(kuò)展,本文就給大家詳細(xì)的介紹一下基于PostgreSQL的時(shí)序數(shù)據(jù)庫TimescaleDB的基本用法和概念,需要的朋友可以參考下2023-06-06PostgreSQL 序列綁定字段與不綁定字段的區(qū)別說明
這篇文章主要介紹了PostgreSQL 序列綁定字段與不綁定字段的區(qū)別說明,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-02-02postgresql 實(shí)現(xiàn)更新序列的起始值
這篇文章主要介紹了postgresql 實(shí)現(xiàn)更新序列的起始值,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-12-12PostgreSQL有效地處理數(shù)據(jù)序列化和反序列化的方法
在 PostgreSQL 中,處理數(shù)據(jù)的序列化和反序列化是確保數(shù)據(jù)在存儲、傳輸和處理過程中的一致性和可用性的重要任務(wù),這涉及到選擇合適的數(shù)據(jù)類型、轉(zhuǎn)換函數(shù)以及在應(yīng)用程序與數(shù)據(jù)庫之間進(jìn)行數(shù)據(jù)交互的策略,需要的朋友可以參考下2024-07-07