截取字符串一般用 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