资讯专栏INFORMATION COLUMN

mysql分页查询总结

dmlllll / 807人阅读

摘要:分页查询总结提供分页的功能子句可以被用于强制语句返回指定的记录数。陕西陕西通过我们可以看出直接查询和通过子查询的差距直接查询子查询分页查询可以看出,通过子查询的方式,子查询是在索引上进行的,而普通的查询是在数据文件上进行的。

mysql分页查询总结

mysql提供分页的功能:

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

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

最简单的用法就是:

select * from table limit ?,?  

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

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查询和通过子查询的差距:

直接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

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

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

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/47506.html

相关文章

  • MySQL分页优化实验与总结

    摘要:前言分页的优化是日常开发中经常遇到的问题,笔者在此做一个经验总结,并附上相应的实验过程。应用程序层面的分页优化设计除了对语句进行优化,我们还可以在应用程序层面对分页进行一些优化设计。 前言 分页的sql优化是日常开发中经常遇到的问题,笔者在此做一个经验总结,并附上相应的实验过程。 实验准备 若不想亲自实验的,可以直接跳过这一节。但还是建议大家做一下实验,眼见为实。 1.安装测试数据库 ...

    Tikitoo 评论0 收藏0
  • Oracle总结【SQL细节、多表查询、分组查询分页

    摘要:前言在之前已经大概了解过数据库和学过相关的知识点,但是太久没用过了,就基本忘了印象中就只有基本的语句和相关一些概念写下本博文的原因就是记载着一些以前没注意到的知识点以后或许会有用实例与数据库概念数据库服务器由两部分组成实例理解为对象看不见的 前言 在之前已经大概了解过Mysql数据库和学过相关的Oracle知识点,但是太久没用过Oracle了,就基本忘了...印象中就只有基本的SQL语...

    陈伟 评论0 收藏0
  • MySQL常见问题总结

    摘要:实现事务的原子性,要支持回滚操作,在某个操作失败后,回滚到事务执行之前的状态。一致性事务使得系统从一个一致的状态转换到另一个一致状态。 本文作者 TomorrowWu,原创文章,转载注明出处,博客地址 https://segmentfault.com/u/to... 第一时间看后续精彩文章。觉得好的话,顺手分享到朋友圈吧,感谢支持。 笔者最近在准备面试,觉得学习最好的方式就是把知道的东...

    springDevBird 评论0 收藏0
  • MySQL常见问题总结

    摘要:实现事务的原子性,要支持回滚操作,在某个操作失败后,回滚到事务执行之前的状态。一致性事务使得系统从一个一致的状态转换到另一个一致状态。 本文作者 TomorrowWu,原创文章,转载注明出处,博客地址 https://segmentfault.com/u/to... 第一时间看后续精彩文章。觉得好的话,顺手分享到朋友圈吧,感谢支持。 笔者最近在准备面试,觉得学习最好的方式就是把知道的东...

    plus2047 评论0 收藏0
  • MySQL常见问题总结

    摘要:实现事务的原子性,要支持回滚操作,在某个操作失败后,回滚到事务执行之前的状态。一致性事务使得系统从一个一致的状态转换到另一个一致状态。 本文作者 TomorrowWu,原创文章,转载注明出处,博客地址 https://segmentfault.com/u/to... 第一时间看后续精彩文章。觉得好的话,顺手分享到朋友圈吧,感谢支持。 笔者最近在准备面试,觉得学习最好的方式就是把知道的东...

    wangxinarhat 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<