- 今天查询一个线上的慢SQL发现了一些问题,记录一下
- 两个表关联查询使用Left join查询 A 表 和B表
select * from A
left join B on B.afcode = A.fcode
- 这里B.afcode 和A.fcode都有索引
- 在网上找了几种不会走索引的情况,但是还没有解决我的问题:
- 如果两个字段或者两张表的编码不同,也会导致索引失效。
- 其次看别人博客中写到,如果where条件中有过滤条件会首先走where条件,但是where条件中的字段导致全表扫描,所以就没有用到指定的索引@see :https://blog.csdn.net/qq_20009015/article/details/91405186
- 这里面的执行顺序为
1.from
2.on
3.join
4.where
5.select
6.group by
7.limit
- 因此,谨记,大表查询的时候,where 的条件千万记得加上索引!!!!
- 二 更改字符集解决问题 @see : https://blog.csdn.net/everda/article/details/77476716
- 三 两张表联合查询为何没有用上索引?原来是上面的语句没有筛选条件,TA.depnum=TB.depnum这个条件只是做了表的关联查询,并未提供筛选条件,如果再加一个条件”and depnum=’001’”等筛选条件,索引立即用上了。 @see: https://blog.csdn.net/u013986317/article/details/102899285
- 使用convert()函数,保证关联的索引字段 转换后两边字符集一致
- Mysql索引查询失效的情况 @see https://www.cnblogs.com/wdss/p/11186411.html
- Explain 分析详解 @see : https://segmentfault.com/a/1190000008131735