Postgresql 截取字符串的案例
程序员文章站
2022-03-13 23:06:44
截取字符串一般用 substring 就够用了。对于有些长度不定的就没法用这个函数了,但还是有规律的,可以某个字符分割。如:(这是一个url,截取最后一部分。现在要取 - 后面部分内容)8a59e88...
截取字符串一般用 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"
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。
推荐阅读
-
解析使用substr截取UTF-8中文字符串出现乱码的问题_PHP
-
正则表达式截取字符串的方法技巧
-
MySQL截取字符串函数的方法_MySQL
-
请问一个字符串截取的有关问题
-
企业案例:查找当前目录下所有文件,并把文件中的https://www.cnblogs.com/zhaokang2019/字符串替换成https://www.cnblogs.com/guobaoyan2019/
-
自定义的PHP字符串截取函数
-
sql话语中能否直接把截取的字符串当作where条件
-
ThinkPHP的截取字符串函数无法显示省略号的解决方法_php实例
-
sql语句中能否直接把截取的字符串当作where条件
-
PHP substr截取字符串时,中文出现乱码的问题解决