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),还是不行,为什么呢,百度了一下,有两个知识点
- Mysql在处理所有的查询的时候都强行转换为连接查询来执行,将每个查询包括多表中关联匹配,关联子查询,union,甚至单表的的查询都处理为连接查询,接着Mysql执行连接查询,把每个联接在处理为一个嵌套循环;
- 在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
文章讨论了一个SQL查询在有索引的情况下仍无法有效利用索引的问题。MySQL会将所有查询转换为连接查询处理,包括子查询,这可能导致性能下降。为优化子查询,建议将其转化为连接查询以利用索引。示例提供了一个将子查询转换为连接查询的优化方法。
205

被折叠的 条评论
为什么被折叠?



