0

0

mysql如何使用limit限制查询结果_mysql结果限制技巧

P粉602998670

P粉602998670

发布时间:2026-02-27 09:15:51

|

868人浏览过

|

来源于php中文网

原创

mysql的limit必须置于最外层select末尾,仅支持单数字或双数字(偏移量+行数)语法,且需配合order by保证结果确定性;分页应避免大offset,改用游标分页;update/delete中limit仅为安全限制,不可替代where;sql_calc_found_rows已弃用。

mysql如何使用limit限制查询结果_mysql结果限制技巧

MySQL 的 LIMIT 必须写在语句末尾,且不能单独用

MySQL 不支持像 PostgreSQL 那样把 LIMIT 放在子查询或 CTE 里随意位置。它只认最外层 SELECT 末尾的 LIMIT,否则直接报错 ERROR 1064

常见错误现象:在 ORDER BY 前加 LIMIT、嵌套子查询里写 LIMIT、或试图用 LIMIT 限制 UPDATE/DELETE 但没加 WHERE(虽语法允许,但极危险)。

  • LIMIT 后可跟一个数字(如 LIMIT 10),表示取前 10 行
  • 也可跟两个数字(如 LIMIT 20, 10),表示跳过前 20 行,取接下来的 10 行 —— 注意这不是“从第 20 行开始”,而是偏移量为 20
  • 如果只想要最新一条记录,别只写 LIMIT 1,必须配合 ORDER BY created_at DESC,否则结果不确定

分页时 LIMIT offset, size 越往后越慢,替代方案要提前想

offset 很大(比如 LIMIT 100000, 20),MySQL 仍会扫描前 100020 行再丢弃,IO 和 CPU 开销陡增。这不是语法问题,是执行逻辑决定的。

使用场景:后台列表翻到几百页后卡顿、导出任务中途超时。

  • 用游标分页(cursor-based pagination):改用上一页最后一条的 id 或时间戳做条件,例如 WHERE id > 12345 ORDER BY id LIMIT 20
  • 避免 OFFSET 超过 10 万级;真要全量导出,优先用 mysqldump 或按主键范围分段查
  • 注意 ORDER BY 字段必须有索引,否则 LIMIT 加速效果归零

LIMITUPDATEDELETE 中能用,但风险极高

MySQL 允许在 UPDATEDELETE 后加 LIMIT,比如 DELETE FROM logs WHERE status = 'error' LIMIT 1000。这能防止误删全表,但容易掩盖逻辑缺陷。

Text Mark
Text Mark

处理文本内容的AI助手

下载

常见错误现象:脚本循环执行带 LIMITDELETE,却没检查是否还有剩余数据,导致删不干净;或者没加 WHERE 条件,仅靠 LIMIT 挡着,一运行就删错行。

  • 生产环境禁止无 WHEREDELETE ... LIMIT,哪怕只是测试
  • 批量清理务必先用 SELECT COUNT(*) 预估影响行数,再用 LIMIT 分批操作
  • UPDATE ... LIMIT 同样依赖 WHERE 精准定位,LIMIT 只是保险绳,不是筛选逻辑

SQL_CALC_FOUND_ROWS 配合查总条数,现在基本该淘汰了

老项目里常见这种写法:SELECT SQL_CALC_FOUND_ROWS * FROM users LIMIT 20,再执行 SELECT FOUND_ROWS()。它会让 MySQL 强制扫描全表统计,即使你只取前 20 行。

性能影响明显:在千万级表上,SQL_CALC_FOUND_ROWS 可能比单纯 LIMIT 慢 5–10 倍。

  • 现代做法是:前端分页显示“下一页”,不显示总页数;或用近似值(如 EXPLAINrows 字段)预估
  • 真需要精确总数,另起一个轻量 SELECT COUNT(*),但记得加好 WHERE 条件,且避免在高并发写入场景频繁查
  • SQL_CALC_FOUND_ROWS 在 MySQL 8.0.17+ 已被标记为 deprecated,后续版本会移除

真正麻烦的从来不是 LIMIT 本身,而是它掩盖了没建对索引、没设计好分页逻辑、或者把数据库当缓存用的问题。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

681

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

432

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

286

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

519

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

264

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

392

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

539

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

639

2023.08.14

Golang 实际项目案例:从需求到上线
Golang 实际项目案例:从需求到上线

《Golang 实际项目案例:从需求到上线》以真实业务场景为主线,完整覆盖需求分析、架构设计、模块拆分、编码实现、性能优化与部署上线全过程,强调工程规范与实践决策,帮助开发者打通从技术实现到系统交付的关键路径,提升独立完成 Go 项目的综合能力。

1

2026.02.26

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.4万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 837人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号