mysql如何实现分页查询功能_mysql项目查询实战

发布时间 - 2026-02-03 00:00:00    点击率:
MySQL分页首选LIMIT+OFFSET,但大数据量时性能差;应加ORDER BY确保稳定性,推荐游标分页或条件分页优化;窗口函数不适用于分页。

MySQL 分页用 LIMITOFFSET 最直接

绝大多数分页场景,靠 LIMIT + OFFSET 就能解决。语法是:SELECT * FROM table LIMIT offset, row_countSELECT * FROM table LIMIT row_count OFFSET offset。前者更常用,也更直观。

比如查第 3 页、每页 10 条:SELECT * FROM users LIMIT 20, 10(跳过前 20 条,取 10 条)。注意:这里的 offset 是从 0 开始计数的,不是页码。

  • 页码转 offset 要小心:第 N 页对应 offset = (N - 1) * page_size

    别写成 N * page_size
  • OFFSET 值很大时(比如 > 10 万),查询会明显变慢,因为 MySQL 仍需扫描并跳过前面所有行
  • 如果表有主键且有序,用「游标分页」(基于上一页最后 ID)比 OFFSET 更高效,尤其用于无限滚动

ORDER BY 必须加,否则分页结果不可靠

没有 ORDER BY 的分页查询,每次执行返回的顺序可能不同,导致同一页数据重复或遗漏。MySQL 不保证无排序时的行返回顺序。

正确写法示例:SELECT id, name FROM products ORDER BY id ASC LIMIT 10 OFFSET 20。推荐用主键或带索引的列排序,避免 ORDER BY RAND() 这类无法利用索引的操作。

  • 如果业务需要按时间倒序,优先用 created_at DESC 并确保该字段有索引
  • 复合排序要明确:比如 ORDER BY status ASC, updated_at DESC,避免因 NULL 或相同值引发顺序漂移
  • 不要在分页 SQL 中动态拼接 ORDER BY 字段名,容易引发 SQL 注入;应通过白名单校验字段合法性

大数据量下 LIMIT M,N 性能骤降的原因和应对

M 很大(例如 LIMIT 1000000, 20),MySQL 实际执行是“读取前 1000020 行,丢弃前 1000000 行”,I/O 和 CPU 开销都集中在无效扫描上。

  • EXPLAIN 显示 rows 值远大于实际返回行数,就是典型信号
  • 用覆盖索引可缓解:例如只查 id,再用这些 id 回表,比直接 SELECT * 快得多
  • 真正高并发、大数据量的分页(如后台管理查百万级日志),建议改用条件分页:记录上一页最大 id,下一页查 WHERE id > ? ORDER BY id LIMIT 20
  • MyISAM 引擎下 LIMIT 性能比 InnoDB 更差,不建议在新项目中使用 MyISAM

MySQL 8.0+ 支持窗口函数,但分页仍不推荐替代 LIMIT

虽然 ROW_NUMBER() 可以实现逻辑分页,比如:SELECT * FROM (SELECT *, ROW_NUMBER() OVER (ORDER BY id) AS rn FROM users) t WHERE rn BETWEEN 21 AND 30,但这只是“模拟”,性能通常更差。

原因在于:窗口函数必须先计算全部行的序号,再过滤,无法提前终止。而 LIMIT 是执行器层的物理限制,MySQL 可以边扫描边截断。

  • 窗口函数适合做“组内排名”“累计统计”,不是为分页设计的
  • 若必须用窗口(如配合复杂聚合后分页),务必加好 ORDER BY 子句,否则 OVER() 报错
  • 低版本 MySQL(FUNCTION xxx does not exist

实际项目里,95% 的分页需求用好 LIMIT + 索引 + 明确 ORDER BY 就够了。真正卡住的往往不是语法,而是没意识到 OFFSET 越大越慢,以及忘了给排序字段建索引。


# mysql  # 大数据  # ai  # sql  # NULL  # select  # 并发  # function  # table  # 分页  # 上一页  # 跳过  # 主键  # 更差  # 子句  # 就能  # 下一页  # 是从  # 每页 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 如何快速搭建高效可靠的建站解决方案?  零服务器AI建站解决方案:快速部署与云端平台低成本实践  javascript如何操作浏览器历史记录_怎样实现无刷新导航  Python面向对象测试方法_mock解析【教程】  图册素材网站设计制作软件,图册的导出方式有几种?  如何在 React 中条件性地遍历数组并渲染元素  如何在万网利用已有域名快速建站?  微信小程序 配置文件详细介绍  如何用VPS主机快速搭建个人网站?  如何用y主机助手快速搭建网站?  详解Android中Activity的四大启动模式实验简述  Laravel队列任务超时怎么办_Laravel Queue Timeout设置详解  Win11摄像头无法使用怎么办_Win11相机隐私权限开启教程【详解】  网站建设要注意的标准 促进网站用户好感度!  合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?  Laravel PHP版本要求一览_Laravel各版本环境要求对照  在线制作视频的网站有哪些,电脑如何制作视频短片?  js实现点击每个li节点,都弹出其文本值及修改  php在windows下怎么调试_phpwindows环境调试操作说明【操作】  rsync同步时出现rsync: failed to set times on “xxxx”: Operation not permitted  使用spring连接及操作mongodb3.0实例  齐河建站公司:营销型网站建设与SEO优化双核驱动策略  html5的keygen标签为什么废弃_替代方案说明【解答】  如何在Windows服务器上快速搭建网站?  Laravel如何处理CORS跨域请求?(配置示例)  今日头条微视频如何找选题 今日头条微视频找选题技巧【指南】  如何续费美橙建站之星域名及服务?  Laravel如何处理CORS跨域问题_Laravel项目CORS配置与解决方案  Win11怎么设置默认图片查看器_Windows11照片应用关联设置  北京网站制作公司哪家好一点,北京租房网站有哪些?  Laravel怎么判断请求类型_Laravel Request isMethod用法  JS弹性运动实现方法分析  Win11关机界面怎么改_Win11自定义关机画面设置【工具】  如何用搬瓦工VPS快速搭建个人网站?  详解免费开源的DotNet二维码操作组件ThoughtWorks.QRCode(.NET组件介绍之四)  网站图片在线制作软件,怎么在图片上做链接?  如何在HTML表单中获取用户输入并结合JavaScript动态控制复利计算循环  Zeus浏览器网页版官网入口 宙斯浏览器官网在线通道  米侠浏览器网页背景异常怎么办 米侠显示修复  教你用AI将一段旋律扩展成一首完整的曲子  Bootstrap整体框架之CSS12栅格系统  怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?  如何在IIS中新建站点并配置端口与物理路径?  佛山网站制作系统,佛山企业变更地址网上办理步骤?  Laravel如何配置Horizon来管理队列?(安装和使用)  Laravel如何使用Passport实现OAuth2?(完整配置步骤)  如何在局域网内绑定自建网站域名?  使用PHP下载CSS文件中的所有图片【几行代码即可实现】  Laravel如何实现用户注册和登录?(Auth脚手架指南)  Swift中switch语句区间和元组模式匹配