从品牌网站建设到网络营销策划,从策略到执行的一站式服务
本篇内容介绍了“MySQL索引失效是什么情况”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
创新互联云计算的互联网服务提供商,拥有超过13年的服务器租用、成都棕树电信机房、云服务器、虚拟空间、网站系统开发经验,已先后获得国家工业和信息化部颁发的互联网数据中心业务许可证。专业提供云主机、虚拟空间、域名注册、VPS主机、云服务器、香港云服务器、免备案服务器等。
在我们常规做数据库开发时,都会为每个表设置适合它的索引来加快数据库的搜索效率。
但有了索引也不是说就万事大吉,所有查询都没问题。像我们使用
但也可能因为你使用错误的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索引失效是什么情况”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注创新互联网站,小编将为大家输出更多高质量的实用文章!
成都网站建设公司地址:成都市青羊区太升南路288号锦天国际A座10层 建设咨询028-86922220
成都快上网科技有限公司-四川网站建设设计公司 | 蜀ICP备19037934号 Copyright 2020,ALL Rights Reserved cdkjz.cn | 成都网站建设 | © Copyright 2020版权所有.
专家团队为您提供成都网站建设,成都网站设计,成都品牌网站设计,成都营销型网站制作等服务,成都建网站就找快上网! | 成都网站建设哪家好? | 网站建设地图