数据分割字符串,像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);
#清空临时表