Postgresql 截取字符串的案例
截取字符串一般用substring就够用了。对于有些长度不定的就没法用这个函数了,但还是有规律的,可以某个字符分割。
如:(这是一个url,截取最后一部分。现在要取-后面部分内容)
8a59e88177ad5e70-20170317120301AB9E.plist 12b8d5c26d83a17f-20170308173008D5DD.plist
这时需要split_part函数,如:
--url一共3个-,字符串被分成4部分,取最后一部分,那最后一个参数就是4
selectsplit_part(fs.cdn_url,'-',4)fromfile_storefs
如果分割符数量不一样怎么办,这里就要计算分割符的数量了
--将1个分隔符替换为2个分隔符,然后用长度相减得到分隔符数
--最后+1是为了取最后一部分内容
selectsplit_part(fs.cdn_url,'-',length(replace(fs.cdn_url,'-','--'))-length(fs.cdn_url)+1)fromfile_storefs
补充:PostgreSQL字符串截取替换
初始化数据库
CREATETABLEpublic.t1 ( nametext ) name ------- "David" "Peter" "任务2016-09-1010:09:00" "任务2016-10-1012:03:00" "任务2016-12-2214:10:00"
把包含"任务"的记录替换为"Job"
updatet1setname='Job'||substring(name,3)wheresubstring(name,position('任务'inname),2)='任务'; select*fromt1; name ------- "David" "Peter" "Job2016-09-1010:09:00" "Job2016-10-1012:03:00" "Job2016-12-2214:10:00"
以上为个人经验,希望能给大家一个参考,也希望大家多多支持毛票票。如有错误或未考虑完全的地方,望不吝赐教。