• 【mysql】单表使用索引常见的索引失效


    1. 全值匹配我最爱

      全值匹配我最爱指的是,查询的字段按照顺序在索引中都可以匹配到!

      SQL 中查询字段的顺序,跟使用索引中字段的顺序,没有关系。优化器会在不影响SQL 执行结果的前提下,给

    你自动地优化。

    2.  最佳左前缀法则

      查询字段与索引字段顺序的不同会导致,索引无法充分使用,甚至索引失效!
      原因:使用复合索引,需要遵循最佳左前缀法则,即如果索引了多列,要遵守最左前缀法则。指的是查询从索
    引的最左前列开始并且不跳过索引中的列。
      结论:过滤条件要使用索引必须按照索引建立时的顺序,依次满足,一旦跳过某个字段,索引后面的字段都无
    法被使用。

    3. 不要在索引列上做任何计算

      不在索引列上做任何操作(计算、函数、(自动or 手动)类型转换),会导致索引失效而转向全表扫描。

    3.1 在查询列上使用了函数

      

      结论:等号左边无计算!

    3.2 在查询列上做了转换

      结论:等号右边无转换!

    4. 索引列上不能有范围查询

       建议:将可能做范围查询的字段的索引顺序放在最后

    5. 尽量使用覆盖索

      即查询列和索引列一直,不要写select *!

     6. 使用不等于(!= 或者<>)的时候索引失效

      mysql 在使用不等于(!= 或者<>)时,有时会无法使用索引会导致全表扫描。

     7. 字段的is not null 和is null

       is not null 用不到索引,is null 可以用到索引。

     

    8. like 的前后模糊匹配

       前缀不能出现模糊匹配!

    9. 减少使用or

      使用or时不走索引。

      使用union all 或者union 来替代:

     10. 口诀

      全职匹配我最爱,最左前缀要遵守;
      带头大哥不能死,中间兄弟不能断;
      索引列上少计算,范围之后全失效;
      LIKE 百分写最右,覆盖索引不写*;
      不等空值还有OR,索引影响要注意;
      VAR 引号不可丢,SQL 优化有诀窍。

    ----尚硅谷_mysql_高级学习笔记

  • 相关阅读:
    Analysis Services 查询性能十大最佳实践(转)
    谈谈一年来对“数据仓库”概念的困惑、探索和感悟(转)
    用sql语句添加删除主键
    大文件流操作及编码
    SQL Server CONVERT() 函数
    正则表达式提取案例1
    解析SQL SERVER存储过程返回值
    文件操作类Path
    HTTP状态码
    自己写的遮罩层效果
  • 原文地址:https://www.cnblogs.com/wjqhuaxia/p/12832469.html
Copyright © 2020-2023  润新知