MySQL索引的分类、何时使用、何时不使用、何时失效?
来自:blog.csdn.net/weixin_39420024/article/details/80040549
1、分类
2、何时使用索引
主键,unique字段; 和其他表做连接的字段需要加索引; 在where里使用>,≥,=,<,≤,is null和between等字段; 使用不以通配符开始的like,where A like 'China%'; 聚集函数MIN(),MAX()中的字段; order by和group by字段;
3、何时不使用索引
表记录太少; 数据重复且分布平均的字段(只有很少数据值的列); 经常插入、删除、修改的表要减少索引; text,image等类型不应该建立索引,这些列的数据量大(假如text前10个字符,也可以对text前10个字符建立索引); MySQL能估计出全表扫描比使用索引更快时,不使用索引;
4、索引何时失效
组合索引未使用左前缀,例如组合索引(A,B),where B=b不会使用索引; like未使用左前缀,where A like '%China'; 搜索一个索引而在另一个索引上做order by,where A=a order by B,只使用A上的索引,因为查询只使用一个索引 ; or会使索引失效。如果查询字段相同,也可以使用索引。例如where A=a1 or A=a2(生效),where A=a or B=b(失效) 如果列类型是字符串,要使用引号。例如where A='China',否则索引失效(会进行类型转换); 在索引列上的操作,函数(upper()等)、or、!=(<>)、not in等;
5、explain语句
ALL: 全表扫描 index: 索引全扫描 range: 索引范围扫描,常用语<,<=,>=,between等操作 ref: 使用非索引扫描或索引前缀扫描,返回单条记录,常出现在关联查询中 eq_ref: 类似ref,区别在于使用的是索引,使用主键的关联查询 const/system: 单条记录,系统会把匹配行中的其他列作为常数处理,如主键或索引查询 null: MySQL不访问任何表或索引,直接返回结果
相关文章