MySQL问题:什么是MySQL的中的最左匹配原则?

是指在复合索引中,查询条件需要按照索引列的顺序从最左侧列开始依次匹配。只有查询条件中的列按照索引的最左边列开始进行匹配,索引才能被有效使用,但有时虽然不是正常顺序,由于MySQL中存在优化器,会自动调整顺序,依旧能使用索引

联合索引的顺序

例如:联合索引(a,b,c)在B+Tree中的排序是:先按a的值排序,如果a的值相同的,则按b的值排序,如果b的值相同,在按c的值排序。

注意:如果遇到范围查询(>,<),就会停止匹配

如果遇到>=、between、like等范围查询,则不会停止匹配,原因:这些查询包含一个凳子判断,这样可以直接定位到某个数据,然后往后扫描即可。

如何设计联合索引?

也就是如何满足最左匹配原则的实现

高频查询字段放左侧,等值查询字段优先于范围查询字段。

相关推荐
Liu1bo17 分钟前
【MySQL】表的约束
linux·数据库·mysql
胖胖的战士32 分钟前
Mysql 数据库迁移
数据库·mysql
czhc11400756631 小时前
LINUX1012 mysql GLIBC安装
数据库·mysql
DemonAvenger1 小时前
深入 Redis Hash:从原理到实战,10 年经验的后端工程师带你玩转哈希结构
数据库·redis·性能优化
❥ღ Komo·2 小时前
PHP数据库操作全攻略
数据库·oracle
程序新视界2 小时前
MySQL的整体架构及功能详解
数据库·后端·mysql
ANYOLY2 小时前
MySQL索引指南
数据库·mysql
怪兽20143 小时前
Redis过期键的删除策略有哪些?
java·数据库·redis·缓存·面试
骑士雄师4 小时前
使用 IntelliJ IDEA 结合 DBeaver 连接 MySQL 数据库并实现数据增删查改的详细步骤:
数据库·mysql·intellij-idea
呼哧呼哧.9 小时前
Spring的核心思想与注解
数据库·sql·spring