MySQL limit 翻页数据重复的问题解决

 更新时间:2026年03月08日 09:36:49   作者:小恒恒  
MySQL5.6引入了LIMIT QueryOptimization特性,可能会导致分页数据重复,下面就来详细的介绍一下MySQL limit 翻页数据重复的问题解决,具有一定的参考价值,感兴趣的可以了解一下

0.背景

Mysql版本:5.7

1.出问题原因

在MySql5.6开始,limit加入了一个新特性:LIMIT Query Optimization。假设你写了这样一个sql:

select * from my_table limit 10,10;

它是符合优化原则的:

MySQL sometimes optimizes a query that has a LIMIT row_count clause and no HAVING clause:

纵览所有的优化原则,发现与我们最普通的情况有关系的也只有这一条:

If an index is not used for ORDER BY but a LIMIT clause is also present, the optimizer may be able to avoid using a merge file and sort the rows in memory using an in-memory filesort operation.

意即:如果索引未用于ORDER BY,但也存在LIMIT子句,则优化器可能能够避免使用合并文件,并使用内存中文件排序操作对内存中的行进行排序。 再有和我们有点关系的可能也就是:

If you select only a few rows with LIMIT, MySQL uses indexes in some cases when normally it would prefer to do a full table scan.

意即:如果您只需要查出几行,MySQL会因为避免全表扫描而在某些情况下使用索引。

MySQL的优化规则很复杂,如果你不明确指定一个不重复的用于order by列,数据库并不保证每一次排序都是一致的,也就是说分页内容会出现重复的可能性。

我认同MySQL order by limit 分页数据重复问题中的观点:

分页是建立在排序的基础上,进行了数量范围分割。排序是数据库提供的功能,而分页却是衍生的出来的应用需求。

故解决问题的方式就很明了了。

2.解决方法

select * from my_table order by id limit 10,10 ;

到此这篇关于MySQL limit 翻页数据重复的问题解决的文章就介绍到这了,更多相关MySQL limit 翻页数据重复内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 浅谈MySQL查询出的值为NULL和N/A和空值的区别

    浅谈MySQL查询出的值为NULL和N/A和空值的区别

    本文主要介绍了浅谈MySQL查询出的值为NULL和N/A和空值的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-01-01
  • mysql占用CPU过高的解决办法(添加索引)

    mysql占用CPU过高的解决办法(添加索引)

    下面是MYSQL占用CPU高处理的一个例子,希望对遇到类似问题的朋友们有点启发。一般来说MYQL占用CPU高,多半是数据库查询代码问题,查询数据库过多。所以一方面要精简代码,另一方面最好对频繁使用的代码设置索引
    2013-03-03
  • 快速解决mysql57服务突然不见了的问题

    快速解决mysql57服务突然不见了的问题

    下面小编就为大家带来一篇快速解决mysql57服务突然不见了的问题。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-05-05
  • MySQL将一个字段中以逗号分隔的取出来形成新的字段实现

    MySQL将一个字段中以逗号分隔的取出来形成新的字段实现

    这篇文章主要介绍了MySQL将一个字段中以逗号分隔的取出来形成新的字段实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-10-10
  • 详解如何在SpringBoot中配置MySQL数据库的连接数

    详解如何在SpringBoot中配置MySQL数据库的连接数

    在Spring Boot中配置MySQL数据库连接数通常涉及到两个主要的配置,数据源配置和连接池配置,本文给大家介绍了Spring Boot项目如何配置MySQL数据库连接数的详细步骤,并通过代码示例讲解的非常详细,需要的朋友可以参考下
    2024-06-06
  • MySQL的触发器全解析(创建、查看触发器)

    MySQL的触发器全解析(创建、查看触发器)

    MySQL触发器是与表关联的存储程序,当INSERT/UPDATE/DELETE事件发生时自动执行,用于维护数据一致性、日志记录和校验,优点包括自动执行,缺点是可读性差且维护难,注意外键约束可能影响触发器激活,下面跟随小编一起学习mysql的触发器知识,感兴趣的朋友一起看看吧
    2025-08-08
  • MySQL存储结构用法案例分析

    MySQL存储结构用法案例分析

    这篇文章主要介绍了MySQL存储结构用法,结合具体案例形式分析了mysql存储结构相关使用方法与操作注意事项,需要的朋友可以参考下
    2018-07-07
  • MySQL将多条数据合并成一条的完整示例

    MySQL将多条数据合并成一条的完整示例

    我们在使用mysql的时候常会遇到合并的需求,下面这篇文章主要给大家介绍了关于MySQL将多条数据合并成一条的相关资料,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2023-02-02
  • 从MySQL 5.5迁移到Mariadb 10.1.14所遇到的问题

    从MySQL 5.5迁移到Mariadb 10.1.14所遇到的问题

    这篇文章主要介绍了从MySQL 5.5迁移到Mariadb 10.1.14所遇到的问题的相关资料,需要的朋友可以参考下
    2016-08-08
  • 一次非法关机导致mysql数据表损坏的实例解决

    一次非法关机导致mysql数据表损坏的实例解决

    本文介绍由于非法硬件关机,造成了mysql的数据表损坏,数据库不能正常运行的一个实例,接下来是作者排查错误的过程,希望对大家能有所帮助
    2013-01-01

最新评论