面试准备+复习分享:
为了应付面试也刷了很多的面试题与资料,现在就分享给有需要的读者朋友,资料我只截取出来一部分哦
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语句
type字段为All,未使用索引;为ref,使用索引
-
ALL: 全表扫描
-
index: 索引全扫描
-
range: 索引范围扫描,常用语<,<=,>=,between等操作
-
ref: 使用非唯一索引扫描或唯一索引前缀扫描,返回单条记录,常出现在关联查询中
-
eq_ref: 类似ref,区别在于使用的是唯一索引,使用主键的关联查询
-
const/system: 单条记录,系统会把匹配行中的其他列作为常数处理,如主键或唯一索引查询
-
null: MySQL不访问任何表或索引,直接返回结果
还有key字段表示用到的索引,没有用到为null
推荐文章
更多项目源码
最后
文章中涉及到的知识点我都已经整理成了资料,录制了视频供大家下载学习,诚意满满,希望可以帮助在这个行业发展的朋友,在论坛博客等地方少花些时间找资料,把有限的时间,真正花在学习上,所以我把这些资料,分享出来。相信对于已经工作和遇到技术瓶颈的朋友们,在这份资料中一定都有你需要的内容。
结学习笔记+最新讲解视频+实战项目源码】](https://bbs.csdn.net/forums/4f45ff00ff254613a03fab5e56a57acb)收录**