mysql完成字符串分割
来源:互联网 发布:四川省网络试听作品 编辑:程序博客网 时间:2024/06/03 17:36
数据分割字符串,像spilt那样按某个符号将字符串分割成多个数组
mysql:
使用方法LENGTH()长度,
SUBSTRING_INDEX()分割字符串,
REPLACE()替换字符串
REVERSE()反转字符串
函数版本(测试使用,仅仅测试原理,不建议使用)
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;
0 0
- mysql完成字符串分割
- mysql 字符串分割函数
- mysql字符串分割
- MySQL分割字符串的实现
- MySQL之Split分割字符串
- Mysql SUBSTRING_INDEX分割字符串用法
- mysql存储过程字符串分割
- MySQL中实现分割字符串的方法
- 用MySQL存储过程分割字符串
- MySql使用存储过程分割字符串
- mysql,sqlserver分割逗号字符串处理
- MySQL字符串分割并拼接语句介绍
- 利用MySQL存储过程分割字符串
- mysql字符串分割和拼接函数介绍
- 利用MySQL存储过程分割字符串
- 利用MySQL存储过程分割字符串
- 利用MySQL存储过程分割字符串
- MySQL中实现分割字符串的方法
- Android 启动模式
- el表达式string强制转换成long报错
- android 5.0 新的特性
- 人才篇-如何识人用人
- Climbing Stairs
- mysql完成字符串分割
- 转载:C++ 实现银行排队服务模拟
- CodeForces 660A Co-prime Array
- 上传应用程序编译时报错:clang: error: unable to execute command: Segmentation fault: 11
- iOS 使用AFNetworking 3.1.0如何在请求头中加入cookie
- L3-001. 凑零钱-PAT团体程序设计天梯赛GPLT(01背包,动态规划)
- Quartz与Spring集成——启动调度器
- 以@为间隔,每5个字符为间距,分隔字符串
- Android6.0运行时权限解决方案