mysql完成字符串分割
2016-08-22 22:18
429 查看
数据分割字符串,像spilt那样按某个符号将字符串分割成多个数组
mysql:
使用方法LENGTH()长度,
SUBSTRING_INDEX()分割字符串,
REPLACE()替换字符串
REVERSE()反转字符串
思路用LENGTH()获得该字符串长度,接着将该字符串的中的分割字符串全部替换成空字符串,再次获得该字符串长度,将两个长度一相减,便可以的到替换字符串的长度,即将要循环的次数,循环REVERSE(SUBSTRING_INDEX(REVERSE(SUBSTRING_INDEX(str,param,@i)),param,1))这一句,去获得所有的数据项,存入临时表
sql语句:
存储过程版本
函数版本(测试使用,仅仅测试原理,不建议使用)
mysql:
使用方法LENGTH()长度,
SUBSTRING_INDEX()分割字符串,
REPLACE()替换字符串
REVERSE()反转字符串
思路用LENGTH()获得该字符串长度,接着将该字符串的中的分割字符串全部替换成空字符串,再次获得该字符串长度,将两个长度一相减,便可以的到替换字符串的长度,即将要循环的次数,循环REVERSE(SUBSTRING_INDEX(REVERSE(SUBSTRING_INDEX(str,param,@i)),param,1))这一句,去获得所有的数据项,存入临时表
sql语句:
存储过程版本
CREATE PROCEDURE str_spilt(IN str varchar(2000),param varchar(50)) BEGIN #分割字符串,用逗号隔开 set @i=0; #如果不存在,择创建一个用于保存分割字符串后数据的临时表str_spilt_result CREATE TEMPORARY TABLE if not exists str_spilt_result(id BIGINT(20) NOT NULL); #清空临时表 truncate table str_spilt_result; SET @cnt = 1+(LENGTH(str) - LENGTH(REPLACE(str,param,''))); WHILE @i < @cnt DO SET @i = @i + 1; SET @result = REVERSE(SUBSTRING_INDEX(REVERSE(SUBSTRING_INDEX(str,param,@i)),param,1)); #把数据插入临时表1 INSERT INTO str_spilt_result(id) VALUES (@result); END WHILE; SELECT * from str_spilt_result; END;测试:
CALL p_spilt('1,2,3,4,5,6',',')
函数版本(测试使用,仅仅测试原理,不建议使用)
CREATE FUNCTION f_spiltStr(DATA1 varchar(50)) RETURNS int(11) BEGIN #分割字符串,用逗号隔开 SET @length = LENGTH(DATA1) - LENGTH(REPLACE(DATA1,',','')); SET @i = 1; WHILE @i<@length+1 DO set @i = @i + 1; SET @val=SUBSTRING_INDEX(SUBSTRING_INDEX(DATA1,',',-@i),',',1); #插入一张用于保存分割字符串结果的表中 INSERT INTO t_sys_text(text) VALUES(CONCAT(@val,'')); END WHILE; RETURN 1; END;
相关文章推荐
- mysql5.7.14源码安装过程中碰到的几个问题.
- 查询mysql中第二大的记录
- JSP中的分页技术源码(MYSQL数据库)
- mysql表内关联
- Mysql InnoDB锁
- 各种主流 SQLServer 迁移到 MySQL 工具对比
- mysql中索引
- mysql 打开数据库连接时,出现1130 -host 'localhost' is not allowed 。。的解决办法
- 《MYSQL技术精粹》读书笔记
- mysql varchar和char类型在不同字符集下的字符数和字节数计算
- MySQL文件目录格式及存放位置
- 修改mysql数据库的密码
- mysql中char与varchar的区别分析
- MySQL can’t specify target table for update in FROM clause
- 深入浅出MySQL(2)
- mysql类型参照
- [置顶] mysql和postgresql使用总结
- MySQL授权
- MySQL存储过程详解 mysql 存储过程
- 提高MySQL效率与性能的技巧