Erlo

Mysql 字符串分隔函数

2019-04-25 11:02:51 发布   370 浏览  
页面报错/反馈
收藏 点赞

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

 

登录查看全部

参与评论

评论留言

还没有评论留言,赶紧来抢楼吧~~

手机查看

返回顶部

给这篇文章打个标签吧~

棒极了 糟糕透顶 好文章 PHP JAVA JS 小程序 Python SEO MySql 确认