简要描述MySQL数据库联合索引的命中规则

  1. mysql的联合查询索引尊姓最左前缀匹配规则,即从联合索引的最左列开始向右匹配,知道遇到匹配的终止条件。例如联合索引(col1、col2、col3),where的条件为col1=a AND col2=`b,可命中该联合索引的(col1、col2)前缀部分,where条件为 col2=‘a’ AND col3='c’的时候,不符合左前缀匹配,不能命中该联合索引
  2. 匹配终止条件为范围操作符(如>、<、 between、like等)或函数等,不能应用索引的情况,例如联合索引(col1、col2、col3),where大的条件为col1=‘a’ AND col2>1 AND col3=‘c’,在col2列上为范围查询,匹配会终止,只能匹配到col1,不能匹配到(col1, col2, col3).
  3. where条件中的顺序不影响索引命中。例如联合索引(col1, col2, col3), where条件为col3=c AND col2=b AND col1=a, MySQL优化器会自行进行优化,可命中联合索引(col1, col2, col3).

猜你喜欢

转载自blog.csdn.net/l2470334493/article/details/108671876