Postgresql 截取字符串

如:(这是一个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 
posted @ 2020-01-22 11:03  small_lei_it  阅读(3375)  评论(0编辑  收藏  举报