MySql split一个字符串

本文详细解析了两个SQL函数(func_get_split_string_total 和 func_get_split_string)和一个过程(splitString),用于处理字符串的分割与计数。通过这些工具,可以有效地按指定分隔符对字符串进行分割,并计算分割后的单元总数,同时还能获取指定位置的分割单元。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.函数func_get_split_string_total:将字符串按指定方式分割,并计算单元总数

CREATE DEFINER=`root`@`localhost` FUNCTION `func_get_split_string_total`(f_string varchar(1000),f_delimiter varchar(5)) RETURNS int(11)
BEGIN
  return 1+(length(f_string) - length(replace(f_string,f_delimiter,'')));
END

2.函数func_get_split_string:将字符串按指定方式分割,获取指定位置的数

CREATE DEFINER=`root`@`localhost` FUNCTION `func_get_split_string`(f_string varchar(1000),f_delimiter varchar(5),f_order int) RETURNS varchar(255) CHARSET utf8
BEGIN
  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

</pre><pre code_snippet_id="498294" snippet_file_name="blog_20141027_3_655983" name="code" class="sql">3.过程splitString 将字符串分割,并放到临时表tmp_split 里面
CREATE DEFINER=`root`@`localhost` PROCEDURE `splitString`(IN f_string varchar(1000),IN f_delimiter varchar(5))
BEGIN      
    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_split;    
    create temporary table tmp_split (val_ varchar(128) not null) DEFAULT CHARSET=utf8;    
 
    while i < cnt    
    do    
        set i = i + 1;    
        insert into tmp_split(val_) values (func_get_split_string(f_string,f_delimiter,i));    
    end while;    
END


</pre><p>4.使用</p><p></p><pre code_snippet_id="498294" snippet_file_name="blog_20141027_7_2403259" name="code" class="sql">call splitString((select fileids from exampaper where id=90),';'); 

select * from xmlinfo where id in (SELECT * from tmp_split)











评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值