LIMIT 子句可以被用于强制 SELECT 语句返回指定的记录数。
LIMIT 接受一个或两个数字参数。
参数必须是一个整数常量。
如果给定两个参数,第一个参数指定第一个返回记录行的偏移量,第二个参数指定返回记录行的最大数目。
举例:
select * from table limit 10000,10
- 上边SQL语句表示从表table中拿数据,跳过10000行之后,拿10行
select * from table limit 0,10
- 表示从表table拿数据,跳过0行之后,拿取10行
select * from table limit 10
- 这条SQL跟3的效果是完全一样的,表示拿前10条数据
存在问题:
在数据量不大或者是大数据量的前几页的时候,性能还算不坏,但是大数据量页码稍微大一点性能便下降比较严重
问题分析
原因出在Limit的偏移量offset上
比如limit 100000,10虽然最后只返回10条数据,但是偏移量却高达100000,数据库的操作其实是拿到100010数据,然后返回最后10条。
解决思路
我能不能跳过100000条数据然后读取10条,而不是读取100010条数据然后返回10条数据。
select * from mytbl order by id limit 100000,10
select * from mytbl where id >= ( select id from mytbl order by id limit 100000,1 ) limit 10
id是主键索引
,那么里层走的是索引,外层也是走的索引,所以性能大大提高