https://www.jb51.net/article/206106.htm
现在有个表 app
id app_name
1 a
2 b
3 c
4 d
在数据库中传一个 1,2,3过来 要得到 a,b,c这样的结果
– 函数如下:
– i_str 表示传进去的 字符串 f_delimit 表示分隔符
drop function if exists func_get_split_string;
create function func_get_split_string(i_str varchar(128), f_delimit varchar(3))
returns varchar(512)
begin
set @rs = ‘’;
set @i = length(i_str) - length(replace(i_str,f_delimit,‘’)); – 算出分隔符的总数
set @sub_str = i_str;
set @left_str = i_str;
while @i>0 – 有多少个分隔符就循环多少遍
do
set @sub_str = substr(@left_str,1,instr(@left_str,f_delimit)-1); – 得到分隔符前面的字符串
set @left_str = substr(@left_str,length(@sub_str)+length(f_delimit)+1); – 得到分隔符后面的字符串
set @n = trim(@sub_str);
select COALESCE(max(app_name),‘’) into @split_string from app where id = @n; – 用分隔符前面的字符串关联查询表
set @i = @i - 1;
set @rs = concat(@rs,‘,’,@split_string); – 将得到的结果放到结果串
end while;
set @n = trim(@left_str);
select COALESCE(max(app_name),‘’) into @split_string from app where id = @n;
set @rs = concat(@rs,‘,’,@split_string);
return substr(@rs,2) ; – 返回去掉最前面的 ,
end;
– 调用函数的办法
select func_get_split_string(‘1,2,3’,‘,’);
MySQL截取和拆分字符串函数用法示例
本文实例讲述了MySQL截取和拆分字符串函数用法。分享给大家供大家参考,具体如下:
首先说截取字符串函数:
1
SUBSTRING(commentid,9)
这个很简单,从第9个字符开始截取到最后。SUBSTRING的参数有三个,最后一个是截取的长度,默认是到结尾,负数是倒数第几位。
接着说拆分字符串函数:
1
SUBSTRING_INDEX(commentid, ‘-’, 1)
这个就稍稍复杂一些了,他的意思是以 - 进行拆分字符串,从第一个关键词开始取前面所有的字符串。如果上面的第三个参数修改为 -1,那么就是取倒数第一个。如果我们想从字符串 c-11065-50 中,取出50或者11065如何写呢?
取得50的写法:
复制代码 代码如下:
SELECT SUBSTRING_INDEX(checkid,‘-’,-1) FROM check
WHERE checkid = ‘c-11065-50’
取得11065的写法:
复制代码 代码如下:
SELECT SUBSTRING_INDEX(SUBSTRING_INDEX(checkid,‘-’,-2),‘-’,1) FROM check WHERE checkid = ‘c-11065-50’
或者:
复制代码 代码如下:
SELECT SUBSTRING_INDEX(SUBSTRING_INDEX(checkid,‘-’,2),‘-’,-1) FROM check WHERE checkid = ‘c-11065-50’
看上去比较复杂了吧,那么再来点更复杂的:
这下面就是组合用法了,例如我们要截取:content_13-11220-1中的13,最简单的就是:
复制代码 代码如下:
SELECT SUBSTRING_INDEX(SUBSTRING_INDEX(SUBSTRING(commentid,9), ‘-’, 1), ‘-’,-1) FROM check WHERE commentid = ‘content_13-11220-1’
我们发现这里需要调用三次函数,有没有可以调用两次的呢。于是我们可以这样写:
复制代码 代码如下:
SELECT SUBSTRING_INDEX(SUBSTRING_INDEX(commentid, ‘-’, 1), ‘_’,-1) FROM check WHERE commentid = ‘content_13-11220-1’
这样就可以少执行一次函数了,当我们运行的数据足够多,那么速度也就显示的很明显了