温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

MySQL索引失效是什么情况

发布时间:2021-07-06 18:30:38 来源:亿速云 阅读:121 作者:chen 栏目:编程语言

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

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

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

但也可能因为你使用错误的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索引失效是什么情况”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI