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