字符串截取

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’

这样就可以少执行一次函数了,当我们运行的数据足够多,那么速度也就显示的很明显了

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值