截取字符串一般用 substring 就够用了。对于有些长度不定的就没法用这个函数了,但还是有规律的,可以某个字符分割。
如:(这是一个url,截取最后一部分。现在要取 - 后面部分内容)
1
2
|
8a59e88177ad5e70-20170317120301AB9E.plist 12b8d5c26d83a17f-20170308173008D5DD.plist |
这时需要 split_part 函数,如:
-- url 一共3个 - ,字符串被分成4部分,取最后一部分,那最后一个参数就是4
1
|
select split_part(fs.cdn_url , '-' , 4) from file_store fs |
如果 分割符 数量不一样怎么办,这里就要计算分割符的数量了
-- 将 1个分隔符 替换为 2个分隔符,然后用长度相减得到分隔符数
-- 最后 +1 是为了取最后一部分内容
1
|
select split_part(fs.cdn_url , '-' , length( replace (fs.cdn_url, '-' , '--' )) - length(fs.cdn_url) + 1) from file_store fs |
补充:PostgreSQL字符串截取替换
初始化数据库
1
2
3
4
5
6
7
8
9
10
11
|
CREATE TABLE public .t1 ( name text ) name ------- "David" "Peter" "任务2016-09-10 10:09:00" "任务2016-10-10 12:03:00" "任务2016-12-22 14:10:00" |
把包含"任务"的记录替换为"Job"
1
2
3
4
5
6
7
8
9
|
update t1 set name = 'Job' || substring ( name ,3) where substring ( name ,position( '任务' in name ),2)= '任务' ; select * from t1; name ------- "David" "Peter" "Job2016-09-10 10:09:00" "Job2016-10-10 12:03:00" "Job2016-12-22 14:10:00" |
以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。如有错误或未考虑完全的地方,望不吝赐教。
原文链接:https://www.jianshu.com/p/6eb8ff8311f8