mysql完成字符串分割

数据分割字符串,像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;



转载于:https://www.cnblogs.com/marx-luo/p/6713076.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值