MySQL中实现分割字符串的方法
来源:互联网 发布:java反射机制的优缺点 编辑:程序博客网 时间:2024/05/20 13:38
MySQL中实现分割字符串的方法
比如现在有一字符串: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 ;
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)
0 0
- MySQL中实现分割字符串的方法
- MySQL中实现分割字符串的方法
- MySQL中实现分割字符串的方法
- MySQL分割字符串的实现
- POSTGRESQL 与MYSQL 实现分割字符串的方法对比
- python中split实现字符串分割方法
- C++中实现字符串分割方法
- 标准C中字符串分割的方法
- MFC中实现字符串的分割
- JS实现Split分割字符串同时允许被分割出的字符串中存在分割符号
- 字符串的分割方法
- 分割字符串的方法
- 分割字符串的方法
- MySQL里实现类似SPLIT的分割字符串的函数
- MySQL里实现类似SPLIT的分割字符串的函数
- MySQL里实现类似SPLIT的分割字符串的函数
- C#实现多个字符分割字符串的方法
- C#中使用split分割字符串的几种方法
- C#控制台基础 结构,类在声明的同时初始化
- 关于JavaScript substr() 方法
- int与string类型转换
- Oracle10g忘记system,sys密码的解决办法。
- 去除行号(Python3)
- MySQL中实现分割字符串的方法
- 更换启动图片
- sourcetree 无法提交代码
- Retrofit2.0 和Instant Run 冲突导致 java.lang.ArrayIndexOutOfBoundsException
- C语言学习3
- tolua++ lib 和 exe的生成
- String类型出生年月计算年龄
- leetcode Maximum Depth of Binary Tree
- poj 2632 Crashing Robots