使用INSTR替换mysql里面的like

Mysql里面的like如果是左右模糊不可以使用索引导致查询效率极低,这时候我们就可以使用Orcal里面的instr来处理使效率提高

// 这段sql是一个左右模糊查询
select * from t_case where name LIKE concat('%','测试','%');

// 使用INSTR来替代
select * from INSTR(name,'测试') > 0;

上面两个sql结果完全相同,但是二者效率较高,这时候很多朋友就会问这到底是什么意思,别着急 我们慢慢了解.
参数一:要查询的字段名
参数二:要查询的值
含义:后面的sql意思就是在要查询的字段name
里面从第一个字开始找要查询内容测试,找到就返回找不到就不返回.
至于为什么要在后面>0我测试了一下 如果作为条件的话不加上>0也是没问题的但是如果是为了查询参数二所在参数一的什么位置就可以不用加了见代码

select INSTR(name,'哈哈');
这句代码返回的就是哈哈在name里面的位置并且返回的是第一个字符在name里面的位置 注意:这里返回的不是索引因为Orcal里面是从1开始没有0,如果后面加上了>0那么返回的就是1,顺带提一下INSTR是Orcal里面的函数但是MySql可以用他两个参数的语法就是本文使用

FIND_IN_SET跟INSTR的区别在于
find_in_set参数二是模糊匹配的范围 而inset参数一是模糊查询的范围
inset的模糊查询范围是任意字符串find_in_set是逗号分割的内容且返回的是匹配到的内容的所在位置值不是索引值,这里返回的值是以逗号分割的来的,具体见下代码

// find_in_set是全词匹配
select FIND_IN_SET('1','122,231,234')
结果 0

select FIND_IN_SET('1','122,231,1')
结果 3
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值