189 8069 5689

MySQL索引失效是什么情况

本篇内容介绍了“MySQL索引失效是什么情况”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

创新互联云计算的互联网服务提供商,拥有超过13年的服务器租用、成都棕树电信机房、云服务器、虚拟空间、网站系统开发经验,已先后获得国家工业和信息化部颁发的互联网数据中心业务许可证。专业提供云主机、虚拟空间、域名注册、VPS主机、云服务器、香港云服务器、免备案服务器等。

在我们常规做数据库开发时,都会为每个表设置适合它的索引来加快数据库的搜索效率。

但有了索引也不是说就万事大吉,所有查询都没问题。像我们使用

但也可能因为你使用错误的SQL语句而无法使用。其中有以下几种,在使用sql查询时尽量避免。

使用!=或<>导致索引失效
select * from user where name <> '张三';
使用模糊查询的索引失效

最左侧不使用%时也会使用索引(最左匹配),否则不使用索引。

select * from user where name like '%三%';
使用not in 或 not exists的索引失效
select * from user where name not in ('张三');
使用is null 或 is not null 的索引失效
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都会导致索引失效,如果or连接的是一个字段,那么就不会失效,反之索引失效。

select * from user where name = '张三' or age > 30;
MySQL查询优化器最终选择不走索引

即使完全符合索引生效的场景,考虑到实际数据量等原因,最终是否使用索引还要看MySQL优化器的判断。当然你也可以在sql语句中写明强制走某个索引。

索引本身失效

这种情况概率极低,我也只遇到过一回,确定where条件使用了索引也执行了查询,但返回的数据结果与实际不相符。未能找到原因,后来只是把这个索引删除后重建就正常了。

“MySQL索引失效是什么情况”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注创新互联网站,小编将为大家输出更多高质量的实用文章!


网页名称:MySQL索引失效是什么情况
文章出自:http://gzruizhi.cn/article/gcpces.html

其他资讯