贝利信息

为什么 MySQL 联合索引必须满足最左前缀原则?

日期:2024-10-27 00:00 / 作者:DDD

MySQL 中最左前缀要求的必要性

问题:

MySQL 中联合索引有最左前缀的要求,即需要查询最左边的列才能使用索引。优化器为什么不能自动调整顺序,使得满足最左前缀条件?

回答:

对最左前缀的理解有误。

如 index('user_id', 'created_at') 索引,虽然查询中 created_at 排在最左,但 user_id 同样满足最左前缀条件,因为 user_id 位于索引的最左边。

最左前缀规则如下:

示例:

联合索引 (a, b, c) 的查询示例:

只有满足最左前缀的查询才能走索引,例如:

注意: