時間:2024-02-03 17:42作者:下載吧人氣:25
作為當前最強大的開源數據庫,Postgresql(以下簡稱pg)對字符的處理也是最為強大的,首先他也有substr,trim等其他數據庫都有的普通函數,這里我們介紹他更強大的一個函數substring,可以像python,java等編程語言一樣使用正則表達式,強大到極點
在此之前我們先了解一下正則表達式最基礎的四個
%代表一個或多個字符 _代表一個字符 ^代表字符前 $代表字符后
pg的官網上對其用法是下面這樣,但不夠清楚了然,下面我一一解釋
用法和substr差不多,是指定序列,from 2 for 3 是從序列為2的位置開始取3個字符。例子如上
例子用法的意思是:$代表字符后, 一個點代表一個字符,即從最末尾開始選擇3個字符,同樣的如果是substring(‘Thomas’ from ‘^….’) 則結果是Thom
用法是最實用的,也是最難理解的,先大致理解:
from ‘%#”o_a#”_’ for ‘#’ 中from是開始(包含),for后面跟的是逃逸,即結束
這個例子的意思是我想要o_a的組合字符,其中o_a的多個(%)字符不要,后面的一個(_)字符不要,這里要注意的是切分后面剩多少字符寫幾個_
這里的架構可以理解為固定的,即 from ‘#”#”‘ for ‘#’ #” 是分割字符,可以在#”前中后限定選擇你最想要的字符
下面用實例來講解一下第三個用法
需求:下圖的查詢結果是查的日志表,我想要【】里的數據,由于【】里字符長度不固定,又只能用sql來切割,因此只能使用第三種方法來獲取【】里的數據
根據上面的思想,我可以寫這樣的架構’【#”%#”_______’ FOR ‘#’,試著運行一下
SELECT
SUBSTRING (
log_txt
FROM
‘【#”%#”_______’ FOR ‘#’
) log_txt
FROM
operation_log
WHERE
log_type = ’15’
LIMIT 3
網友評論