本篇内容介绍了“MySQL索引失效是什么情况”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
在我们常规做数据库开发时,都会为每个表设置适合它的索引来加快数据库的搜索效率。
但有了索引也不是说就万事大吉,所有查询都没问题。像我们使用
但也可能因为你使用错误的SQL语句而无法使用。其中有以下几种,在使用sql查询时尽量避免。
select * from user where name <> '张三';
最左侧不使用%时也会使用索引(最左匹配),否则不使用索引。
select * from user where name like '%三%';
select * from user where name not in ('张三');
select * from user where name is not null;
select * from user where date(create_time) = '2021-02-03';
查询条件类型与字段类型不相符时,如下边例子,字段是字符串类型条件使用数值类型。
select * from user where name > 30;
包括(+、-、*、/)都会导致索引失效
select * from user where age + 2 = 30;
or导致索引失效是在特定情况下,并不是所有的or都会导致索引失效,如果or连接的是一个字段,那么就不会失效,反之索引失效。
select * from user where name = '张三' or age > 30;
即使完全符合索引生效的场景,考虑到实际数据量等原因,最终是否使用索引还要看MySQL优化器的判断。当然你也可以在sql语句中写明强制走某个索引。
这种情况概率极低,我也只遇到过一回,确定where条件使用了索引也执行了查询,但返回的数据结果与实际不相符。未能找到原因,后来只是把这个索引删除后重建就正常了。
“MySQL索引失效是什么情况”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。