Mysql 字符串分隔函数
/**
* 字符串分隔方法
* 获取字符串分隔之后的数组长度
*/
drop function if exists `func_get_split_total`;
delimiter ;;
create function `func_get_split_total`(
f_string text, # 长度不够会导致临时表数据不全,# mysql字符类型varchar有长度限制(最大65535),改用text文本类型
f_delimiter varchar(5)) returns int(11)
deterministic
comment '获取字符串分隔后的长度'
begin
return 1+(length(f_string) - length(replace(f_string,f_delimiter,'')));
end
;;
delimiter ;
/**
* 获取字符串分隔后的对应下标的值,下标从1开始
*/
drop function if exists `func_get_split_value`;
delimiter ;;
create function `func_get_split_value`(
f_string text, # 长度不够会导致临时表数据不全,# mysql字符类型varchar有长度限制(最大65535),改用text文本类型
f_delimiter varchar(5),
f_order int) returns varchar(255) charset utf8mb4
deterministic
comment '获取字符串分隔后的对应下标的值,下标从1开始'
begin
declare result varchar(255) default '';
set result = reverse(substring_index(reverse(substring_index(f_string,f_delimiter,f_order)),f_delimiter,1));
return result;
end
;;
delimiter ;
# #
select func_get_split_total('a/b/c','/') ; # 3
select func_get_split_value('a/b/c','/',1) ; # a
上一篇: 阿里云centos安装docker
下一篇: MySQL的安装步骤