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