服务器硬件-Postgresql 截取字符串的案例
截取字符串一般用服务器硬件 substring 就够用了。对于有些长度不定的就没法用这个函数了,但仍是有规律的,能够某个字符切割。
如:(这是一个url,截取最终一部分。现在要取 – 后边部分内容)
8a59e88177ad5e70-20170317120301AB9E.plist12b8d5c26d83a17f-20170308173008D5DD.plist
这时需求 split_part 函数,如:
— url 总共3个 – ,字符串被分红4部分,取最终一部分,那最终一个参数便是4
1select split_part(fs.cdn_url ,’-‘, 4) from file_store fs
如果 切割符 数量不一样怎么办,这里就要核算切割符的数量了
— 将 1个分隔符 替换为 2个分隔符,然后用长度相减得到分隔符数
— 最终 +1 是为了取最终一部分内容
1select 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”