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
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值