Postgresql 截取字符串

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

作者:_流浪的猫_

链接:https://www.jianshu.com/p/6eb8ff8311f8

来源:简书

简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

    原文作者:PostgreSQL
    原文地址: https://www.cnblogs.com/telwanggs/p/10688311.html
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞