当前位置:网站首页>mysql分页查询实例_mysql分页查询实例讲解「建议收藏」
mysql分页查询实例_mysql分页查询实例讲解「建议收藏」
2022-07-27 11:35:00 【全栈程序员站长】
大家好,又见面了,我是你们的朋友全栈君。
LIMIT子句可以被用于强制 SELECT 语句返回指定的记录数。LIMIT 接受一个或两个数字参数。参数必须是一个整数常量。如果给定两个参数,第一个参数指定第一个返回记录行的偏移量,第二个参数指定返回记录行的最大数目。初始记录行的偏移量是 0(而不是 1)。下面,我们针对特例对mysql分页查询进行总结。
mysql提供分页的功能:SELECT * FROM table LIMIT [offset,] rows | rows OFFSET offset
最简单的用法就是: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查询:typepossible_keyskeykey_lenrefrowsExtraALL(NULL)(NULL)(NULL)(NULL)4076607子查询分页查询:typepossible_keyskeykey_lenrefrowsExtraPRIMARYrangePRIMARYPRIMARY42038331Using where
SUBQUERYindex(NULL)PRIMARY44076663Using 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://javaforall.cn/128200.html原文链接:https://javaforall.cn
边栏推荐
- LAN SDN technology hard core insider 12 cloud CP's daily love - hardware vxlan forwarding plane
- V-show failure
- Leetcode 01: t1. sum of two numbers; T1108. IP address invalidation; T344. Reverse string
- 【机器学习-白板推导系列】学习笔记---概率图模型和指数族分布
- omitempty在go中的使用
- LAN SDN hard core technology insider 25 looking forward to the future - RDMA (Part 2)
- SMA TE: Semi-Supervised Spatio-Temporal RepresentationLearning on Multivariate Time Series
- LNMP架构搭建(部署Discuz论坛)
- Open source Flink has datastream connector written with holo or Flink SQL Conn
- Sword finger offer notes: T53 - I. find numbers in the sorted array
猜你喜欢

Matlab draws Bode diagram with time delay system

【机器学习-白板推导系列】学习笔记---条件随机场

Newton Raphson iterative method

JS-寄生组合式继承

Source code compilation and installation lamp

Keil MDK compilation appears..\user\stm32f10x H (428): error: # 67: expected a "}" wrong solution

EfficientNet

哈希表 详细讲解

MySQL数据库主从复制集群原理概念以及搭建流程

Adobe Audition提示 音频输入的采样率与输出设备不匹配——问题解决
随机推荐
Difference between verification and calibration
数据库 cli 工具 docker 镜像
JUC框架 从Runnable到Callable到FutureTask 使用浅析
美现首例孕妇猴痘病例:新生儿被注射免疫球蛋白,已安全出生
TapNet: Multivariate Time Series Classification with Attentional Prototypical Network
[untitled] multimodal model clip
剑指 Offer 笔记: T57 - II. 和为 s 的连续正数序列
Weibo comment crawler + visualization
【机器学习-白板推导系列】学习笔记---支持向量机和主成分分析法
pytorch和tensorflow一样展示summary
LeetCode 04: T26. 删除排序数组中的重复项(简单); 剑指 Offer 67. 把字符串转换成整数(中等); 面试题 01.08. 零矩阵 (简单)
Could not load dynamic library ‘libcudnn.so.8‘;
【机器学习-白板推导系列】学习笔记---概率图模型和指数族分布
哈希表 详细讲解
Sword finger offer notes: t57 - ii Continuous positive sequence with sum s
Detailed explanation of MATLAB S-function
【机器学习-白板推导系列】学习笔记---条件随机场
Keil MDK compilation appears..\user\stm32f10x H (428): error: # 67: expected a "}" wrong solution
暂用 Solo,博客选择困难
希腊字母读法