首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Mysql分页order by数据错乱重复

作久项目代码优化,公司用的是Mybatis,发现分页和排序时直接传递参数占位符用的都是 $,由于$有SQL注入风险,要改为#,但是封装page类又麻烦,所以直接使用了 pageHelper...插件了,方便快捷,但是测试时发现数据有问题: //第二页 SELECT id, createtime, idnumber, mac FROM `tblmacwhitelist` ORDER BY...SELECT id, createtime, idnumber, mac FROM `tblmacwhitelist` ORDER BY idnumber DESC LIMIT 15 , 5 分页数量正常...,但这3条SQL的结果集是一样的,第二第三第四页的数据,一模一样,我一脸懵逼,后来查了mysql官方文档返现: If multiple rows have identical values in the...大概意思是 :一旦 order by 的 colunm 有多个相同的值的话,结果集是非常不稳定 那怎么解决呢,其实很简单,就是order by 加上唯一不重复的列即可,即在后面加上一个唯一索引就可以了,

2.4K30

Mysql排序后分页,因数据重复导致分页数据紊乱的问题

背景 前不久在写一个分页接口的时候,在测试阶段出现了排序结果紊乱且数据不正确的问题,那个接口是按照create_time进行排序的,但是对应的表中有很多相同create_time的数据,最后发现是因为 ...(0.05 秒) 排序字段出现重复数据,这时可以加入第二个排序字段,提高排序的唯一性, mysql> select * from people order by create_time asc,id...(0.03 秒) 我们可以观察到第一次的查询中,缺少了‘孙七’的数据行,当我们加上了第二个排序字段时分页数据变得正常了。...总结 MySQL 使用 limit 进行分页时,可能会出现重复数据,通过加入 order by 子句可以解决,但是需要注意的是,如果排序字段有相同值的情况下,由于排序字段数据重复,可能会导致每次查询排序后结果顺序不同...,分页还是会出现重复数据,这时可以加入第二个排序字段,提高排序的唯一性,最好保证排序的字段在表中的值是唯一的,这样就可以少写一个排序字段,增加查询效率,因为 order by 后面有多个排序字段时,无法用到索引

70810
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    mysql 5.6 order by limit 排序分页数据重复问题

    之所以MySQL 5.6出现了第二页数据重复的问题,是因为 priority queue 使用了堆排序的排序方法,而堆排序是一个不稳定的排序方法,也就是相同的值可能排序出来的结果和读出来的数据顺序不一致...排序是数据库提供的功能,而分页却是衍生的出来的应用需求。 在MySQL和Oracle的官方文档中提供了limit n和rownum < n的方法,但却没有明确的定义分页这个概念。...所以,分页一直都有这个问题,不同场景对数据分页都没有非常高的准确性要求。...一些常见的数据库排序问题 不加order by的时候的排序问题 用户在使用Oracle或MySQL的时候,发现MySQL总是有序的,Oracle却很混乱,这个主要是因为Oracle是堆表,MySQL...分页问题 分页重复的问题 如前面所描述的,分页是在数据库提供的排序功能的基础上,衍生出来的应用需求,数据库并不保证分页重复问题。

    1K40

    小心避坑:MySQL分页时出现的数据重复问题

    之所以MySQL 5.6出现了第二页数据重复的问题,是因为 priority queue 使用了堆排序的排序方法,而堆排序是一个不稳定的排序方法,也就是相同的值可能排序出来的结果和读出来的数据顺序不一致...排序是数据库提供的功能,而分页却是衍生出来的应用需求。 在MySQL和Oracle的官方文档中提供了limit n和rownum < n的方法,但却没有明确的定义分页这个概念。...所以,分页一直都有这个问题,不同场景对数据分页都没有非常高的准确性要求。...3.一些常见的数据库排序问题 不加order by的时候的排序问题 用户在使用Oracle或MySQL的时候,发现MySQL总是有序的,Oracle却很混乱,这个主要是因为Oracle是堆表,MySQL...分页问题 分页重复的问题 如前面所描述的,分页是在数据库提供的排序功能的基础上,衍生出来的应用需求,数据库并不保证分页重复问题。

    66810

    MySQL 使用 order by limit 分页排序会导致数据丢失和重复

    问题 最近在项目中遇到一个很神奇的问题,MySQL 使用 order by 进行排序并进行分页的时候,会出现部分数据丢失和重复。具体看下面这三张图 ? 图一 ? 图二 ?...很明显的发现,当进行数据分页时,部分数据出现了丢失和重复。 分析原因 在 MySQL 关系型数据库中,往往会存在多种排序算法。...根据上面的总结,当 order by limit 分页出现数据丢失和重复。...在图二、图三中,增加主键 category_id 字段排序后,就不会出现数据丢失和重复了。 ? ?...总结 如果查询数据进行排序和分页时,如果排序字段没有使用索引,一定要添加一个有索引的字段,比如主键 ID,保证顺序稳定。否则,查询的数据会导致数据丢失和重复

    5.6K30

    MYSQL分页查询时没有用ORDER BY出现数据重复的问题

    背景 产品反馈,用户在使用分页列表时,出现数据重复的问题,查看代码后发现对应的分页SQL并没有使用order by进行排序,但是印象中Mysql的InnoDB引擎会默认按照主键id进行排序,本地测试了一下的确出现了部分数据在不同的页都出现的问题...但是,如果该顺序不是确定性的,即可能有重复的值,则在每个具有相同值的组中,由于与上述相同的原因,该顺序是“随机的”。...如果没有定义 order by MySQL使用SELECT 语句不加ORDER BY默认是如何排序的 那返回的数据不一定是按照主键来排序的,结果可以以任意顺序返回 - 也可能随着时间而改变。...对于同样的一批数据,在某一个时刻顺序是一样的,随着时间变化,数据会发生变化,那么在进行查询的时候,MySQL 会尝试以尽可能快的方法(MySQL 实际的方法不见得快)返回数据。...这是所有 SQL 的属性,而不仅仅是 MySQL

    1.6K11

    如何解决MySQL order by limit语句的分页数据重复问题?

    之所以MySQL 5.6出现了第二页数据重复的问题,是因为 priority queue 使用了堆排序的排序方法,而堆排序是一个不稳定的排序方法 也就是相同的值可能排序出来的结果和读出来的数据顺序不一致...排序是数据库提供的功能,而分页却是衍生的出来的应用需求。 在MySQL和Oracle的官方文档中提供了limit n和rownum < n的方法,但却没有明确的定义分页这个概念。...所以,分页一直都有这个问题,不同场景对数据分页都没有非常高的准确性要求。...(3)一些常见的数据库排序问题 不加order by的时候的排序问题 用户在使用Oracle或MySQL的时候,发现MySQL总是有序的,Oracle却很混乱,这个主要是因为Oracle是堆表,MySQL...分页问题 分页重复的问题 如前面所描述的,分页是在数据库提供的排序功能的基础上,衍生出来的应用需求,数据库并不保证分页重复问题。

    1.4K20

    MySQL - 当LIMIT 进行分页时,为什么出现了重复数据

    说在前面 数据分页是后台经常要使用的技术手段,有时候进行数据库查询会根据业务需要对某一字段排序,那么当待排序字段值相同时,我们得到的查询结果会是什么呢?...问题描述 数据分页时需要根据数据记录创建时间create_time字段倒序,即使用order by create_time desc,但是我们会发现,前端进行请求时获取的数据并不正确,分页中出现了一定的重复数据...问题原因 期初还很好奇,总数没问题,总查询也没问题,为什么数据重复了,然后会把部分数据给覆盖了。...后来,通过查看SQL发现,是根据时间进行排序的,然而 这个时间 恰恰 好多数据都是 同一时间插入,或者 设置的 同一时间。 先后执行 总查询(也就是不分页),是没有重复。...,这也是导致我们分页查询时出现重复数据的问题原因。

    4.4K20

    如何解决MySQL order by limit语句的分页数据重复问题?

    之所以MySQL 5.6出现了第二页数据重复的问题,是因为 priority queue 使用了堆排序的排序方法,而堆排序是一个不稳定的排序方法 也就是相同的值可能排序出来的结果和读出来的数据顺序不一致...排序是数据库提供的功能,而分页却是衍生的出来的应用需求。 在MySQL和Oracle的官方文档中提供了limit n和rownum < n的方法,但却没有明确的定义分页这个概念。...所以,分页一直都有这个问题,不同场景对数据分页都没有非常高的准确性要求。...(3)一些常见的数据库排序问题 不加order by的时候的排序问题 用户在使用Oracle或MySQL的时候,发现MySQL总是有序的,Oracle却很混乱,这个主要是因为Oracle是堆表,MySQL...分页问题 分页重复的问题 如前面所描述的,分页是在数据库提供的排序功能的基础上,衍生出来的应用需求,数据库并不保证分页重复问题。

    3K20

    java mysql 分页_mysql分页查询总结

    mysql分页查询总结 mysql提供分页的功能: SELECT * FROM table LIMIT [offset,] rows | rows OFFSET offset LIMIT子句可以被用于强制...下面,我们针对特例对mysql分页查询进行总结。 最简单的用法就是: select * from table limit ?,? 这种是最简单的limit分页查询。...以上两种情况,对于小数据分页查询时,这样的sql就足够用了。但是对于百万级以上的数据表,如果使用上边的sql 的话,越往后limit语句的偏移量越来越大,查询就会变得越来越慢。...通常来说,索引文件要比数据文件小的多,所以操作索引文件更直接高效。...(但是,子查询需要在内存中建立临时表,查询完毕后,MySQL需要撤销这些临时表。

    3.7K20

    处理MySQL 重复数据记录

    有些 MySQL 数据表中可能存在重复的记录,有些情况我们允许重复数据的存在,但有时候我们也需要删除这些重复数据。 本章节我们将为大家介绍如何防止数据表出现重复数据及如何删除数据表中的重复数据。...---- 防止表中出现重复数据 你可以在 MySQL 数据表中设置指定的字段为 PRIMARY KEY(主键) 或者 UNIQUE(唯一) 索引来保证数据的唯一性。...以下实例使用了 INSERT IGNORE INTO,执行后不会出错,也不会向数据表中插入重复数据mysql> INSERT IGNORE INTO person_tbl (last_name, first_name...mysql> SELECT DISTINCT last_name, first_name -> FROM person_tbl; 你也可以使用 GROUP BY 来读取数据表中不重复数据mysql...如果你想删除数据表中的重复数据,你可以使用以下的SQL语句: mysql> CREATE TABLE tmp SELECT last_name, first_name, sex FROM person_tbl

    3.3K00
    领券