美文网首页php
MySQL中为避免索引失效所需注意的问题

MySQL中为避免索引失效所需注意的问题

作者: pedro7 | 来源:发表于2020-09-06 14:11 被阅读0次

    一、索引介绍

    索引介绍

    二、索引的优势与劣势

    1、优势
    • 类似于书籍的目录索引,提高数据检索的效率,降低数据库的IO成本。
    • 通过索引列对数据进行排序,降低数据排序的成本,降低CPU的消耗。
    2、劣势
    • 实际上索引也是一张表,该表中保存了主键与索引字段,并指向实体类的记录,所以索引列也是要占用空间 的。
    • 虽然索引大大提高了查询效率,同时却也降低更新表的速度,如对表进行INSERT、UPDATE、DELETE。因为 更新表时,MySQL 不仅要保存数据,还要保存一下索引文件每次更新添加了索引列的字段,都会调整因为更新所带来的键值变化后的索引信

    三、准备环境

    image.png

    四、避免索引失效的注意点

    1、全值匹配

    全值匹配 ,对索引中所有列都指定具体值。该情况下,索引生效,执行效率高。


    image.png
    2、最左前缀法则

    如果索引了多列,要遵守左前缀法则。指的是查询从索引的左前列开始,并且不跳过索引中的列。
    创建索引的方式:

    image.png
    Ⅰ、匹配最左前缀法则,走索引
    image.png
    Ⅱ、违背最左前缀法则,索引失效
    image.png
    Ⅲ、如果符合最左前缀法则,但是出现跳跃某一列,则只有左列索引生效
    image.png
    3、范围查询右边的列,不能使用索引

    如下,范围查询之后的address没有使用索引


    image.png
    4、不要在索引列上进行运算操作,索引将失效
    image.png
    5、字符串不加单引号,造成索引失效

    由于,在查询时,没有对字符串加单引号,MySQL的查询优化器,会自动的进行类型转换,造成索引失效。


    image.png
    6、尽量使用覆盖索引,避免select *
    image.png
    image.png
    7、or前面的列有索引,后面没有,那么索引不会被使用

    示例,name 字段是索引列 , 而 createtime 不是索引列,中间是 or 进行连接是不走索引的 :


    image.png
    8、以%开头的like模糊查询,索引失效

    如果仅仅是尾部模糊匹配,索引不会失效。如果是头部模糊匹配,索引失效。

    image.png
    解决方案:覆盖索引
    image.png
    9、如果mysql评估使用索引比全表更慢,则不使用索引
    image.png
    10、is NULL,is not NULL有时索引失效
    image.png
    这里索引失效的原因其实就是上面的第九条
    11、in 走索引, not in 索引失效。
    image.png
    12、尽量使用复合索引,而少使用单列索引 。
    image.png

    2020-9-6

    相关文章

      网友评论

        本文标题:MySQL中为避免索引失效所需注意的问题

        本文链接:https://www.haomeiwen.com/subject/iodcektx.html