explain + sql
Type类型及区别
type | 说明 |
---|---|
ALL | 全数据表扫描 |
index | 全索引表扫描 |
RANGE | 对索引列进行范围查找 |
INDEX_MERGE | 合并索引,使用多个单列索引搜索 |
REF | 根据索引查找一个或多个值 |
EQ_REF | 搜索时使用primary key 或 unique类型 |
CONST | 常量,表最多有一个匹配行,因为仅有一行,在这行的列值可被优化器剩余部分认为是常数,const表很快,因为它们只读取一次。 |
SYSTEM | 系统,表仅有一行(=系统表)。这是const联接类型的一个特例。 |
性能:all
< index
< range
< index_merge
< ref_or_null
< ref
< eq_ref
< system/const
联合索引遵循最左原则
一下几种情况不会走索引
- 使用 like 语句时,%在右边才会使用索引。
没用使用索引
使用索引
- or 条件中有未建立索引的列才,索引失效
没用使用索引
使用索引
- 条件的类型不一致
没用使用索引
使用索引
- != 号
没用使用索引
例外:如果是主键,则会走索引 - > 号
没用使用索引
例外:如果是主键或索引是整数类型,则会走索引 - order by
没用使用索引
例外:如果 order by 是主键或索引是整数类型,则会走索引 - 组合索引
遵循最左前缀