Mysql left join不使用索引问题总结

  • 今天查询一个线上的慢SQL发现了一些问题,记录一下
  • 两个表关联查询使用Left join查询 A 表 和B表

select * from A
left join B on B.afcode = A.fcode

  • 这里B.afcode 和A.fcode都有索引
  • 在网上找了几种不会走索引的情况,但是还没有解决我的问题:
  1. 如果两个字段或者两张表的编码不同,也会导致索引失效。
  2. 其次看别人博客中写到,如果where条件中有过滤条件会首先走where条件,但是where条件中的字段导致全表扫描,所以就没有用到指定的索引@see :https://blog.csdn.net/qq_20009015/article/details/91405186
  3. 这里面的执行顺序为

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
发布了27 篇原创文章 · 获赞 4 · 访问量 3171

猜你喜欢

转载自blog.csdn.net/u012019209/article/details/102914832