关于Mysql子查询查询速度慢和索引失效的问题

sql如下:

SELECT * FROM dang_user 
WHERE id 
in(SELECT MAX(id) FROM dang_user WHERE if_use = 1 GROUP BY dang_username)

这个语句没走索引,这里面的字段都是有索引的,后来强制 FORCE INDEX(id),还是不行,为什么呢,百度了一下,有两个知识点

  1. Mysql在处理所有的查询的时候都强行转换为连接查询来执行,将每个查询包括多表中关联匹配,关联子查询,union,甚至单表的的查询都处理为连接查询,接着Mysql执行连接查询,把每个联接在处理为一个嵌套循环;
  2. 在Mysql在处理子查询的时候,会将子查询改写,Mysql将会扫描外查询中的所有数据,每条数据都将会传到子查询中进行关联,子查询不会被首先执行,如果外表很大的话,那么性能上将会出现问题

sql优化:(将子查询转为链接查询就可以走索引啦)

select d.*
from 
(select MAX(id) id from dang_user WHERE if_use = 1 GROUP BY dang_username) as o 
inner join 
dang_user d 
on o.id = d.id

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值