­

mysql完成字符串分割

  • 2019 年 10 月 30 日
  • 笔记

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

本文链接:https://blog.csdn.net/luo4105/article/details/52278975

数据分割字符串,像spilt那样按某个符号将字符串分割成多个数组 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;