mysql进行指定切割_mysql对指定字符串进行切割插入表

分割字符串为数组需要用到 三个mysql 的函数 :

REVERSE(str)

返回颠倒字符顺序的字符串str。

SUBSTRING_INDEX(str,delim,count)

返回从字符串str的第count个出现的分隔符delim之后的子串。如果count是正数,返回最后的分隔符到左边(从左边数) 的所有字符。如果count是负数,返回最后的分隔符到右边的所有字符(从右边数)。

REPLACE(str,from_str,to_str)

返回字符串str,其字符串from_str的所有出现由字符串to_str代替。

通过三个函数的组合使用做到分割字符串为数组的功能。

获得所有以“某个符号“分割的字符串的个数,函数内容如下

(将sql代码复制放在navicat中执行即可)

DELIMITER $$

CREATE DEFINER=`root`@`%` FUNCTION `func_get_split_string_total`(

f_string varchar(1000),f_delimiter varchar(5)

) RETURNS int(11)

BEGIN

-- Get the total number of given string.

return 1+(length(f_string) - length(replace(f_string,f_delimiter,'')))/3;

END$$

DELIMITER ;

这边的除以3表示切割的字符串的长度,计算根据指定字符串进行切割后的个数,就是求需要切割的个数加一即可.我这边测试切割的是’|||’,如果是逗号就将3改为1即可.

然后就可以呢看见函数:

6aa46b7893c95e8336c3960ea048cb54.png

2. 按分割取出字符串

DELIMITER $$

CREATE DEFINER=`root`@`%` FUNCTION `func_get_split_string`(

f_string varchar(1000),f_delimiter varchar(5),f_order int) RETURNS varchar(255) CHARSET utf8

BEGIN

-- Get the separated number of given string.

declare result varchar(255) default '';

set result = reverse(substring_index(reverse(substring_index(f_string,f_delimiter,f_order)),f_delimiter,1));

return result;

END$$

DELIMITER ;

然后再写一个存储过程进行组合使用这两个函数,输入需要分割的字符串 ,和分隔符,输出 按某某符号分割后的数组,插入临时表

DELIMITER $$

CREATE PROCEDURE `sp_print_result`(

IN f_string varchar(1000),IN f_delimiter varchar(100)

)

BEGIN

-- Get the separated string.

declare cnt int default 0;

declare i int default 0;

set cnt = func_get_split_string_total(f_string,f_delimiter);

drop table if exists tmp_print;

create temporary table tmp_print (num VARCHAR(110));

while i < cnt

do

set i = i + 1;

insert into tmp_print(num) values (func_get_split_string(f_string,f_delimiter,i));

end while;

select * from tmp_print;

END$$

DELIMITER ;

临时表我使用varchar,原作者是使用的int.可以进行修改.

可能执行的时候会报错:The user specified as a definer (‘root’@’%’) does not exist

执行 :grant all privileges on . to root@"%" identified by “.”;

执行 :flush privileges;

然后测试我自己的:

call sp_print_result('www.111.com|||www.111.com|||www.111.com|||www.222.com|||www.3333.com|||www.baiddsfu3.com|||www.4444.com|||www.5555.com','|||');

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值