• 【Java面试】这道互联网高频面试题难住了80%的程序员?索引什么时候失效?


    “索引什么时候失效?”

    面试过程中,突如其来的一个问题,是不是有点懵?

    我是Mic,一个工作了14年的Java程序员。

    索引失效涉及到的知识点非常多,所以我把这个问题的回答整理到了一个20W字的面试文档里面,大家可以领取。

    下面看看高手的回答

    高手:

    InnoDB引擎里面有两种索引类型,一种是主键索引、一种是普通索引。

    InnoDB用了B+树的结构来存储索引数据。

    当使用索引列进行数据查询的时候,最终会到主键索引树中查询对应的数据行进行返回。

    理论上来说,使用索引列查询,就能很好的提升查询效率,但是不规范的使用会导致索引失效,从而无法发挥索引本身的价值。

    导致索引失效的情况有很多:

    1. 在索引列上做运算,比如使用函数,Mysql在生成执行计划的时候,它是根据统计信息来判断是否要使用索引的。

      而在索引列上加函数运算,导致Mysql无法识别索引列,也就不会再走索引了。

      不过从Mysql8开始,增加了函数索引可以解决这个问题。

    在一个由多列构成的组合索引中,需要按照最左匹配法则,也就是从索引的最左列开始顺序检索,否则不会走索引。
    
    在组合索引中,索引的存储结构是按照索引列的顺序来存储的,因此在sql中也需要按照这个顺序才能进行逐一匹配。
    
    否则InnoDB无法识别索引导致索引失效。
    
    • 1
    • 2
    • 3
    • 4
    • 5
    1. 当索引列存在隐式转化的时候, 比如索引列是字符串类型,但是在sql查询中没有使用引号。

      那么Mysql会自动进行类型转化,从而导致索引失效。

    2. 在索引列使用不等于号、not查询的时候,由于索引数据的检索效率非常低,因此Mysql引擎会判断不走索引。

    3. 使用like通配符匹配后缀%xxx的时候,由于这种方式不符合索引的最左匹配原则,所以也不会走索引。

      但是反过来,如果通配符匹配的是前缀xxx%,符合最左匹配,也会走索引。在此我向大家推荐一个架构学习交流圈。交流学习指导伪鑫:1253431195(里面有大量的面试题及答案)里面会分享一些资深架构师录制的视频录像:有Spring,MyBatis,Netty源码分析,高并发、高性能、分布式、微服务架构的原理,JVM性能优化、分布式架构等这些成为架构师必备的知识体系。还能领取免费的学习资源,目前受益良多

    4. 使用or连接查询的时候,or语句前后没有同时使用索引,那么索引会失效。只有or左右查询字段都是索引列的时候,才会生效。

    除了这些场景以外,对于多表连接查询的场景中,连接顺序也会影响索引的使用。

    不过最终是否走索引,我们可以使用explain命令来查看sql的执行计划,然后针对性的进行调优即可。

    总结

    Mysql里面很多问题都可以考察毕竟它也是工作中使用非常频繁的组件,按道理来说,我们是有必要去深度学习Mysql的底层原理。

    毕竟数据的安全性、数据IO性能都会影响到系统的整体吞吐量

  • 相关阅读:
    二分图最大匹配(匈牙利算法)
    基于SSM的学生信息管理系统
    【暑期每日一题】洛谷 P7540 [COCI2009-2010#1] DOMINO
    第五章《数据降维:深入理解 PCA 的来龙去脉》笔记
    Disk Drill for Mac v5.0.1043 苹果数据恢复软件
    MTO与MTS下的需求不汇总及在排产中的应用
    MongoDB 中的锁分析
    BGP学习笔记
    【JavaEE】_Spring MVC项目之使用对象传参
    WFP实现侧边栏导航菜单
  • 原文地址:https://blog.csdn.net/java_dazhuzhu/article/details/126199612