/**
* 字符串分隔方法
* 获取字符串分隔之后的数组长度
*/
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
如对本文有疑问, 点击进行留言回复!!
数据库优化-索引的创建-MySQL-index-SQL优化-避免全表扫描
mysql 获取数据库表所有字段,GROUP_CONCAT()拼接字段缺失问题解决
网友评论