mysql分页查询实例讲解


本文摘自PHP中文网,作者小云云,侵删。

LIMIT子句可以被用于强制 SELECT 语句返回指定的记录数。LIMIT 接受一个或两个数字参数。参数必须是一个整数常量。如果给定两个参数,第一个参数指定第一个返回记录行的偏移量,第二个参数指定返回记录行的最大数目。初始记录行的偏移量是 0(而不是 1)。下面,我们针对特例对mysql分页查询进行总结。

mysql提供分页的功能:

1

SELECT * FROM table LIMIT [offset,] rows | rows OFFSET offset

最简单的用法就是:

1

select * from table limit ?,?

这种是最简单的limit分页查询。配合where条件使用:

1

select * from table where column > ? order by id limit ?,?

上边这种情况,建议在column和id建立复合索引比较好。
以上两种情况,对于小数据量分页查询时,这样的sql就足够用了。但是对于百万级以上的数据表,如果使用上边的sql 的话,越往后limit语句的偏移量越来越大,查询就会变得越来越慢。类似于:

1

select * from `user` where `cate`='陕西' order by id limit 100000,10

为了避免这种查询,我们可以通过子查询的方式来提高查询效率。

1

select * from `user` where id >=(select * from `user` where `cate`='陕西' order by id limit 100000,1) and `cate`='陕西' limit 10

通过explain我们可以看出直接limit查询和通过子查询的差距:

直接limit查询:
typepossible_keyskeykey_lenrefrowsExtra
ALL(NULL)(NULL)(NULL)(NULL)4076607
子查询分页查询:
typepossible_keyskeykey_lenrefrowsExtra
PRIMARYrangePRIMARYPRIMARY42038331Using where
SUBQUERYindex(NULL)PRIMARY44076663Using index

可以看出,通过子查询的方式,子查询是在索引上进行的,而普通的查询是在数据文件上进行的。 通常来说,索引文件要比数据文件小的多,所以操作索引文件更直接高效。

此外,还可以通过join分页方式

1

2

3

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可以避免这种情况)在分页查询前,可以进行判断,如果是在限定页数内,就使用基本分页查询,大于则使用子查询分页处理。

相关推荐:

mysql分页性能探索

MySQL分页优化的测试案例

MySQL分页性能优化指南

以上就是mysql分页查询实例讲解的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

mysql创建表的sql语句详细总结

mysql优化常用方法

如何将mysql升级到5.7

mysql适配器pymysql详解

mysql能处理json吗

8种手动和自动备份mysql数据库的方法

mysql源码包如何安装

mysql的数据类型有哪些?

mysql router怎么样

mysql如何在win10中配置环境变量

更多相关阅读请进入《mysql》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...