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