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

补充:PostgreSQL字符串截取替换

初始化数据库

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"

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"

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。

标签:
Postgresql,截取,字符串

免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
狼山资源网 Copyright www.pvsay.com

评论“Postgresql 截取字符串的案例”

暂无“Postgresql 截取字符串的案例”评论...

P70系列延期,华为新旗舰将在下月发布

3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。

而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?

根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。