zoukankan      html  css  js  c++  java
  • 索引的最左前缀原则

    索引的最左前缀原则

    原理
    • mysql建立多列索引(联合索引)有最左前缀的原则,即最左优先,如:
      • 如果有一个2列的索引(col1,col2),则已经对(col1)、(col1,col2)上建立了索引;
      • 如果有一个3列索引(col1,col2,col3),则已经对(col1)、(col1,col2)、(col1,col2,col3)上建立了索引;
    范围查询
    • 范围列可以用到索引(必须是最左前缀),但是范围列后面的列无法用到索引。同时,索引最多用于一个范围列,因此如果查询条件中有两个范围列则无法全用到索引。
    • mysql会一直向右匹配直到遇到范围查询(>、<、between、like)就停止匹配,比如a = 1 and b = 2 and c > 3 and d = 4 如果建立(a,b,c,d)顺序的索引,d是用不到索引的,如果建立(a,b,d,c)的索引则都可以用到,a,b,d的顺序可以任意调整。
    • 如where a>10 order by b ,索引a_b 无法排序
    • =和in可以乱序,比如a = 1 and b = 2 and c = 3 建立(a,b,c)索引可以任意顺序,mysql的查询优化器会帮你优化成索引可以识别的形式
    查询条件中含有函数或表达式
    • 如果查询条件中含有函数或表达式,则MySQL不会为这列使用索引(虽然某些在数学意义上可以使用)
    • 因此在写查询语句时尽量避免表达式出现在查询中,而是先手工私下代数运算,转换为无表达式的查询语句
    什么时候索引会失效
    • 如果条件中有or,即使其中有条件带索引也不会使用(这也是为什么尽量少用or的原因)。注意:要想使用or,又想让索引生效,只能将or条件中的每个列都加上索引
    • 对于多列索引,不是使用的第一部分,则不会使用索引(即不符合最左前缀原则)
    • like查询是以%开头
    • 如果列类型是字符串,那一定要在条件中将数据使用引号引用起来,否则不使用索引
    • 如果mysql估计使用全表扫描要比使用索引快,则不使用索引
  • 相关阅读:
    三种按键处理函数
    enum与typedef enum的用法
    PIC18F中断定时器
    .net core Ocelot+Consul实现网关及服务注册和服务发现
    wpf的优点
    ASP.NET Core Web API下事件驱动型架构的实现
    2020个人计划
    图解C#的值类型,引用类型,栈,堆,ref,out
    .NET Core中的一个接口多种实现的依赖注入与动态选择
    redis分布式锁深度剖析
  • 原文地址:https://www.cnblogs.com/frankltf/p/10368509.html
Copyright © 2011-2022 走看看