例如:
l
imit offset,rows
优化后的子查询语句还是需要获取offset+rows条数据,然后扔掉前offset条数据,但是只查询了id一个字段,对于数据量大的表来说,优化很多,而且,在优化后的语句里可以使用byname的覆盖索引
但个人认为更快的情况下 还是要在程序里先计算出id的值
利用 select * from table where id>? order by id desc limit 10来查询结果集
关于用limit取某张表最后的几行数据
很明显下面这种查询使用了全表扫描
但当order by 和limit一起使用时 且order by的字段上有索引时 如下
可以发现效率有了很大的提升
原因是 读取所有的还要排序。直接走id的索引取最后20条就可以了
http://blog.csdn.net/hguisu/article/details/7161981 --order by 原理优化