MySQL中实现分割字符串的方法
来源:互联网 发布:8684公交软件下载 编辑:程序博客网 时间:2024/05/20 15:38
比如现在有一字符串:1,2,44,5,666,29232
要把它按照逗号分割成:
1
2
44
5
666
29232
而且还要求它的总数。这个我以前写过。不过今天规范一下。
1、具体函数
SQL code DELIMITER $$ CREATE DEFINER=`root`@`%` FUNCTION `func_get_split_string_total`( f_string varchar(1000),f_delimiter varchar(5) ) RETURNS int(11) BEGIN -- Get the total number of given string. return 1+(length(f_string) - length(replace(f_string,f_delimiter,''))); END$$ DELIMITER ;SQL code DELIMITER $$ CREATE DEFINER=`root`@`%` FUNCTION `func_get_split_string`( f_string varchar(1000),f_delimiter varchar(5),f_order int) RETURNS varchar(255) CHARSET utf8 BEGIN -- Get the separated number of given string. 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 ;测试的存储过程: DELIMITER $$ CREATE PROCEDURE `sp_print_result`( IN f_string varchar(1000),IN f_delimiter varchar(5) ) BEGIN -- Get the separated string. declare cnt int default 0; declare i int default 0; set cnt = func_get_split_string_total(f_string,f_delimiter); drop table if exists tmp_print; create temporary table tmp_print (num int not null); while i < cnt do set i = i + 1; insert into tmp_print(num) values (func_get_split_string(f_string,f_delimiter,i)); end while; select * from tmp_print; END$$ DELIMITER ;
2、来做一下测试
mysql> call sp_print_result('1,2,44,5,666,29232',',');+-------+| num |+-------+| 1 || 2 || 44 || 5 || 666 || 29232 |+-------+6 rows in set (0.01 sec)Query OK, 0 rows affected (0.01 sec)
From:http://blog.chinaunix.net/u/29134/showart_1002486.html
0 0
- MySQL中实现分割字符串的方法
- MySQL中实现分割字符串的方法
- MySQL中实现分割字符串的方法
- MySQL分割字符串的实现
- POSTGRESQL 与MYSQL 实现分割字符串的方法对比
- python中split实现字符串分割方法
- C++中实现字符串分割方法
- 标准C中字符串分割的方法
- MFC中实现字符串的分割
- JS实现Split分割字符串同时允许被分割出的字符串中存在分割符号
- 字符串的分割方法
- 分割字符串的方法
- 分割字符串的方法
- MySQL里实现类似SPLIT的分割字符串的函数
- MySQL里实现类似SPLIT的分割字符串的函数
- MySQL里实现类似SPLIT的分割字符串的函数
- C#实现多个字符分割字符串的方法
- C#中使用split分割字符串的几种方法
- 从 0.99999... = 1 到芝诺悖论
- Oracle建立表空间和用户
- C语言第十三篇:简单文字处理
- php代码与表格元素的结合
- Java输入输出流(2)
- MySQL中实现分割字符串的方法
- android 解析、生成二维码
- Android WebView与JS的数据交互
- Brotli压缩算法
- PHP编码规范
- x264_param_t参数注解
- 2011年吉林大学计算机研究生机试真题
- 标记语言总结
- html5绘制折线图