mysql分页查询总结
mysql提供分页的功能:mysql
SELECT * FROM table LIMIT [offset,] rows | rows OFFSET offset
LIMIT子句能够被用于强制 SELECT 语句返回指定的记录数。LIMIT 接受一个或两个数字参数。参数必须是一个整数常量。若是给定两个参数,第一个参数指定第一个返回记录行的偏移量,第二个参数指定返回记录行的最大数目。初始记录行的偏移量是 0(而不是 1)。下面,咱们针对特例对mysql分页查询进行总结。 sql
最简单的用法就是:spa
select * from table limit ?,?
这种是最简单的limit分页查询。配合where条件使用:code
select * from table where column > ? order by id limit ?,?
上边这种状况,建议在column和id创建复合索引比较好。
以上两种状况,对于小数据量分页查询时,这样的sql就足够用了。可是对于百万级以上的数据表,若是使用上边的sql 的话,越日后limit语句的偏移量愈来愈大,查询就会变得愈来愈慢。相似于:索引
select * from `user` where `cate`='陕西' order by id limit 100000,10
为了不这种查询,咱们能够经过子查询的方式来提升查询效率。内存
select * from `user` where id >=(select * from `user` where `cate`='陕西' order by id limit 100000,1) and `cate`='陕西' limit 10
经过explain咱们能够看出直接limit查询和经过子查询的差距:it
直接limit查询:
type | possible_keys | key | key_len | ref | rows | Extra |
---|---|---|---|---|---|---|
ALL | (NULL) | (NULL) | (NULL) | (NULL) | 4076607 |
子查询分页查询:
type | possible_keys | key | key_len | ref | rows | Extra |
---|---|---|---|---|---|---|
PRIMARY | range | PRIMARY | PRIMARY | 4 | 2038331 | Using where |
SUBQUERY | index | (NULL) | PRIMARY | 4 | 4076663 | Using index |
能够看出,经过子查询的方式,子查询是在索引上进行的,而普通的查询是在数据文件上进行的。 一般来讲,索引文件要比数据文件小的多,因此操做索引文件更直接高效。table
此外,还能够经过join分页方式效率
SELECT * FROM `user` AS t1 JOIN (SELECT id FROM `user` ORDER BY id LIMIT 100000, 1) AS t2 WHERE t1.id <= t2.id ORDER BY t1.id LIMIT 10;
join分页和子查询分页的效率基本在一个等级上。(可是,子查询须要在内存中创建临时表,查询完毕后,MySQL须要撤销这些临时表。经过join能够避免这种状况)在分页查询前,能够进行判断,若是是在限定页数内,就使用基本分页查询,大于则使用子查询分页处理。select