欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Mysql 字符串分隔函数

程序员文章站 2024-01-22 16:51:46
/*** 字符串分隔方法* 获取字符串分隔之后的数组长度*/DROP FUNCTION IF EXISTS `func_get_split_total`;DELIMITER ;;CREATE FUNCTION `func_get_split_total`( f_string text, # 长度不够 ......

/**
* 字符串分隔方法
* 获取字符串分隔之后的数组长度
*/
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