分享一下split()

-无-为- 2009-11-17 09:03:22

DELIMITER $$

USE `test`$$

DROP FUNCTION IF EXISTS `func_get_split_string`$$

CREATE DEFINER=`root`@`localhost` FUNCTION `func_get_split_string`(f_string VARCHAR(1000),f_delimiter VARCHAR(5),f_order INT) RETURNS VARCHAR(255) CHARSET utf8
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 ;

效果

mysql> SELECT func_get_split_string('9001#10018#15#','#',3);
+-----------------------------------------------+
| func_get_split_string('9001#10018#15#','#',3) |
+-----------------------------------------------+
| 15 |
+-----------------------------------------------+
1 row in set (0.02 sec)


使用,当然也可以直接REVERSE(SUBSTRING_INDEX(REVERSE(SUBSTRING_INDEX(f_string,f_delimiter,f_order)),f_delimiter,1));


DELIMITER $$

USE `test`$$

DROP FUNCTION IF EXISTS `countOrder`$$

CREATE DEFINER=`root`@`localhost` FUNCTION `countOrder`(f_string VARCHAR(1000),f_delimiter VARCHAR(5)) RETURNS VARCHAR(255) CHARSET utf8
BEGIN
DECLARE result VARCHAR(255) DEFAULT '';
DECLARE lastresult VARCHAR(255) DEFAULT '';
DECLARE f_order INT DEFAULT 1;

SET result=func_get_split_string(f_string,f_delimiter,f_order);

WHILE TRIM(result)!='' DO
SET lastresult=CONCAT_WS(' ',lastresult,NULL,result);
SET f_order=f_order+1;
SET result=func_get_split_string(f_string,f_delimiter,f_order);
END WHILE;

RETURN lastresult;
END$$

DELIMITER ;

...全文
75 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
sgtzzc 2009-11-17
  • 打赏
  • 举报
回复
学习
-无-为- 2009-11-17
  • 打赏
  • 举报
回复
(⊙v⊙)嗯 找到了这个函数 我就要继续修改 原来的那个触发器了 开工..
-无-为- 2009-11-17
  • 打赏
  • 举报
回复
这个函数 应用的就是您说的

SET result = REVERSE(SUBSTRING_INDEX(REVERSE(SUBSTRING_INDEX(f_string,f_delimiter,f_order)),f_delimiter,1));

-无-为- 2009-11-17
  • 打赏
  • 举报
回复
谢谢版主 这一个星期的学习 还是有很多收获 谢谢您的帮助..
ACMAIN_CHM 2009-11-17
  • 打赏
  • 举报
回复

思路不错。

另外在MYSQL中你还可以用
mysql> select SUBSTRING_INDEX(SUBSTRING_INDEX('9001#10018#15#','#',3),'#',-1);
+-----------------------------------------------------------------+
| SUBSTRING_INDEX(SUBSTRING_INDEX('9001#10018#15#','#',3),'#',-1) |
+-----------------------------------------------------------------+
| 15 |
+-----------------------------------------------------------------+
1 row in set (0.36 sec)

mysql>

56,677

社区成员

发帖
与我相关
我的任务
社区描述
MySQL相关内容讨论专区
社区管理员
  • MySQL
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧