当前位置: 首页 > news >正文

在mysql8查询中使用ORDER BY结合LIMIT时,分页查询时出现后一页的数据重复前一页的部分数据。

这里写目录标题

  • 问题描述:
  • 问题模拟:
  • 原因分析
  • 问题解释
  • 问题解决
  • 验证
  • 官方文档支持

问题描述:

在mysql8查询中使用ORDER BY结合LIMIT时,分页查询时出现后一页的数据重复前一页的部分数据。

问题模拟:

  • 表table_lock_test(忽视表名)中的字段及数据如下,
    在这里插入图片描述
    表中总共14条数据,其中11条数据的version列的值是相同的!

  • 使用ORDER BY结合LIMIT进行分页查询,查询第1、2页:(每页显示7条),进行对比

SELECT * FROM table_lock_test ORDER BY `version` DESC LIMIT 7;
SELECT * FROM table_lock_test ORDER BY `version` DESC LIMIT 7,7;

对比结果如下:
在这里插入图片描述

原因分析

  • 看如下两个查询
  1. 根据version列排序,查询前10条数据
    在这里插入图片描述

  2. 根据version列排序,查询前5条数据
    在这里插入图片描述

  3. 根据以上对比,可大胆猜测,ORDER BY与LIMIT结合使用时,如果被排序ORDER BY的列的值相同,那么它们的查询结果的顺序,可能不固定。

问题解释

当查询第2页数据时,id为14 (- HJUIO- 4)的数据的顺序并不在第3的位置,而是出现在了第11的位置,作为第2页的数据再返回了, 这时结合第1页的查询数据就出现了1条重复数据; 同时,必然会出现重复多少条就会有多少数据凭空消失,结合上面的对比图可知这里消失的是id 为 8 的数据。

问题解决

如果排序ORDER BY列有相同的值的时候,再添加一个索引 INDEX列,如主键列一起排序就不会出现上面的数据重复、数据消失的问题了

验证

  • 使用ORDER BY结合LIMIT进行分页查询,查询第1、2页:(每页显示7条),进行对比, 排序时增加INDEX列,这里增加id
SELECT * FROM table_lock_test ORDER BY `version` DESC,id LIMIT 7;
SELECT * FROM table_lock_test ORDER BY `version` DESC,id LIMIT 7,7;

对比结果如下:
在这里插入图片描述

官方文档支持

Msql8操作手册-mysql-refman-8.0-en 第8章-8.2.1.19
在这里插入图片描述

相关文章:

在mysql8查询中使用ORDER BY结合LIMIT时,分页查询时出现后一页的数据重复前一页的部分数据。

这里写目录标题 问题描述:问题模拟:原因分析问题解释问题解决验证官方文档支持 问题描述: 在mysql8查询中使用ORDER BY结合LIMIT时,分页查询时出现后一页的数据重复前一页的部分数据。 问题模拟: 表table_lock_test&…...

【SA8295P 源码分析 (三)】97 - QNX AIS Camera 框架介绍 及 Camera 工作流程分析

【SA8295P 源码分析】97 - QNX AIS Camera 框架介绍 及 Camera 工作流程分析 一、QNX AIS Server 框架分析二、QNX Hypervisor / Android GVM 方案介绍三、Camera APP 调用流程分析四、QCarCam 状态转换过程介绍五、Camera 加串-解串 硬件链路分析六、摄像头初始化检测过程介绍…...

基于epoll封装非阻塞的reactor框架(附源码)

C++常用功能源码系列 文章目录 C++常用功能源码系列前言一、reactor架构二、client端reactor代码三、server端reactor代码四、单reactor架构可以实现百万并发总结前言 本文是C/C++常用功能代码封装专栏的导航贴。部分来源于实战项目中的部分功能提炼,希望能够达到你在自己的项…...

安装Git和git命令使用

文章目录 安装Git创建版本库版本回退工作区和暂存区管理修改撤销修改 安装Git 在Windows上安装Git 在Windows上使用Git,可以从Git官网直接下载安装程序,然后按默认选项安装即可。 安装完成后,在开始菜单里找到“Git”->“Git Bash”&…...

【SA8295P 源码分析 (四)】65 - emac0-phy 与 emac1-switch兼容 方案实现

【SA8295P 源码分析】65 - emac0-phy 与 emac1-switch兼容 方案实现 系列文章汇总见:《【SA8295P 源码分析 (四)】网络模块 文章链接汇总 - 持续更新中》 本文链接:《【SA8295P 源码分析 (四)】65 - emac0-phy 与 emac1-switch兼容 方案实现》 本文在前文《【SA8295P 源码分析…...

SpringSecurity源码学习二:异常处理

目录 1. 原理2. 组件3. ExceptionTranslationFilter3.1 默认过滤器顺序3.2 ExceptionTranslationFilter源码3.2.1 AuthenticationException异常3.2.2 AccessDeniedException异常 总结 1. 原理 Spring Security 异常处理的原理是通过一系列的异常处理器来处理在安全验证和授权过…...

代码随想录算法训练营第23期day28|491.递增子序列 46.全排列 47.全排列 II

目录 一、(leetcode 491)递增子序列 二、(leetcode 46)全排列 三、(leetcode 47)全排列 II 一、(leetcode 491)递增子序列 力扣题目链接 状态:去重方法错误。 这道题…...

ubuntu磁盘扩容

1、参考链接: https://blog.csdn.net/qq_43265072/article/details/112312223 2、尝试过程中小心翼翼,生怕待会系统崩掉,要重装。。。 不过呢有撤销和提交按钮就非常贴心,如果稍有不慎就一路回撤就好啦 说一下怎么移动空间&…...

C/S架构学习之使用select实现TCP小型并发服务器

select实现TCP小型并发服务器的流程:一、创建套接字(socket函数):通信域选择IPV4网络协议、套接字类型选择流式; int sockfd socket(AF_INET,SOCK_STREAM,0); //通信域选择IPV4、套接字类型选择流式二、填充服务器的网…...

公司注册类型分类标准是怎样的

公司法上的分支机构、分公司、子公司是什么 - 公司法 (一)以公司股东的责任范围为标准分类 以公司股东的责任范围为标准,亦即以公司股东是否对公司债务承担责任为标准,可将公司分为无限责任公司、两合公司、股份两合公司、股份有限公司和有限责任公司。…...

5.MidBook项目经验之MongoDB,Nacos,网关

1.医院查询接口 //系统1(signsignMD5加密后) ----> 系统2(数据库signMD5加密 相对比),好处在于网络之间传输不会得到直接得到sign 2.上传和删除科室信息 //map转jsonString,然后再转为对象//保存需要查数据库是否存在,存在修改,不存在添加//接口的包引入不对导致调用引包错误…...

XMLHttpRequest对象的Get请求和Post请求的用法

XMLHttpRequest对象的Get请求和Post请求的用法 Get请求提交数据 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>发送ajax get请求</title> </head> <body> <script type"…...

Tomcat动静分离

访问静态页面和访问动态页面分开&#xff0c;实现动态页面和静态页面的负载均衡 一、七层动静分离 3台虚拟机 1、nginx1既是代理也是静态 nginx1&#xff1a;20.0.0.11 2、请求动态页面&#xff1a;Tomcat1和Tomcat2 Tomcat1&#xff1a;20.0.0.31 Tomcat2&#xff1a;20…...

一些ECharts配置

基于vue3&#xff0c;EChart5.4.3版本 Line <script setup lang"ts"> import {onBeforeUnmount, onMounted, ref, watch} from "vue" import {useEcharts, type ECOption} from "/composables" import * as echarts from "echarts/c…...

C调用Objective-C的类和方法

C调用Objective-C的类和方法 最近有一个C提供回调接口调用Objective-c接口来传递数据的需求&#xff0c;研究了很久&#xff0c;最终通过bing的AI对话查到了需要的内容&#xff0c;这里记录一下&#xff0c;算是给基于C的IOS开发开了一个头。 在Objective-C中&#xff0c;你可…...

驱动开发day1

头文件 #ifndef __HEAD_H__ #define __HEAD_H__ #define PHY_LED1_MODER 0X50006000 #define PHY_LED1_ODR 0X50006014#define PHY_LED2_MODER 0x50007000 #define PHY_LED2_ODR 0x50007014#define PHY_LED3_MODER 0x50006000 #define PHY_LED3_ODR 0x50006014#define P…...

C++ linux vscode编译

.cpp .h文件关系与编译命令 单一cpp文件编译多个.cpp文件编译.h头文件和.cpp源文件在同一目录下编译.h头文件和.cpp源文件在不同一目录下编译 单一cpp文件编译 //test.cpp为测试源文件&#xff0c; a.out为输出可执行文件 g test.cpp -o a.out多个.cpp文件编译 目录1结构如下…...

卷积神经网络CNN学习笔记

目录 1.全连接层存在的问题2.卷积运算3.填充(padding)3.1填充(padding)的意义 4.步幅(stride)5.三维数据的卷积运算6.结合方块思考7.批处理8.conv2d代码参考文章 1.全连接层存在的问题 在全连接层中&#xff0c;相邻层的神经元全部连接在一起&#xff0c;输出的数量可以任意决…...

Java的Socket Timeout和tcp的存活探测包是不是一个东西

背景 你有没有好奇过我们在java中通过Socket.setSoTimeout()设置timeout参数时&#xff0c;他怎么做到在timeout时间到了之后连接就报错的&#xff1f;有没有产生过误解&#xff0c;这个参数就是设置keepalive探测包的检测间隔&#xff1f; 问题真相 其实Socket.setSoTimeou…...

基于跳蛛优化的BP神经网络(分类应用) - 附代码

基于跳蛛优化的BP神经网络&#xff08;分类应用&#xff09; - 附代码 文章目录 基于跳蛛优化的BP神经网络&#xff08;分类应用&#xff09; - 附代码1.鸢尾花iris数据介绍2.数据集整理3.跳蛛优化BP神经网络3.1 BP神经网络参数设置3.2 跳蛛算法应用 4.测试结果&#xff1a;5.M…...

如何免费获得7款专业级思源宋体:设计师必备的完整字体包指南 [特殊字符]

如何免费获得7款专业级思源宋体&#xff1a;设计师必备的完整字体包指南 &#x1f3a8; 【免费下载链接】source-han-serif-ttf Source Han Serif TTF 项目地址: https://gitcode.com/gh_mirrors/so/source-han-serif-ttf 还在为中文设计项目寻找高质量字体而烦恼吗&…...

2026年第十七届蓝桥杯网络安全赛项WriteUp

解题情况比赛还剩一小时左右时截图题型&#xff1a;情报收集题目名&#xff1a;map_tracer查看js源码得到信息&#xff0c;访问/app.js可以得到app.js.map文件用记事本打开&#xff0c;可以得到关键信息接口&#xff1a;/api/trace/internal/list签名值&#xff1a;trace_dev_2…...

蓝桥杯嵌入式备赛:用STM32CubeMX和Keil搞定按键消抖的三种实战方法(附完整代码)

蓝桥杯嵌入式备赛&#xff1a;STM32按键消抖三大方案深度评测与代码实战 在嵌入式系统开发中&#xff0c;按键处理看似简单实则暗藏玄机。特别是在蓝桥杯嵌入式竞赛这类对稳定性和效率要求极高的场景中&#xff0c;一个可靠的按键处理方案往往能决定项目的成败。本文将带你深入…...

保姆级教程:在ROS Melodic下,用代码一步步搞懂map、odom、base_link的TF树关系

ROS Melodic实战&#xff1a;从代码层面解析map、odom与base_link的TF树构建 当你在ROS中开发SLAM或导航功能时&#xff0c;是否遇到过机器人定位突然"飘移"的情况&#xff1f;或是发现tf转换报错导致整个系统崩溃&#xff1f;这些问题的根源往往在于对TF树的理解不够…...

Nacos核心架构解析与生产环境部署实战指南

1. 项目概述&#xff1a;从微服务基石到云原生标配如果你在过去几年里深度参与过微服务架构的落地&#xff0c;或者正在为服务发现、配置管理这些基础但至关重要的环节头疼&#xff0c;那么“Nacos”这个名字对你来说一定不陌生。它不是一个凭空出现的新玩具&#xff0c;而是阿…...

豆瓣Top250电影数据爬取保姆级教程:从UA伪装到数据清洗,新手避坑指南

豆瓣Top250电影数据爬取实战&#xff1a;从零开始避开99%新手陷阱 第一次尝试用Python爬取豆瓣电影数据时&#xff0c;我盯着屏幕上那个刺眼的418状态码整整半小时。和大多数新手一样&#xff0c;我以为只要几行代码就能轻松获取数据&#xff0c;却没想到连第一道门都进不去。本…...

别再只懂JWT三部分了:手把手教你用Node.js + Express实战JWT登录与权限控制

别再只懂JWT三部分了&#xff1a;手把手教你用Node.js Express实战JWT登录与权限控制 每次看到技术文章里"JWT由Header、Payload、Signature三部分组成"的科普&#xff0c;我都想问问作者&#xff1a;您自己实现过完整的JWT流程吗&#xff1f;三年前我第一次在项目中…...

小米R4A千兆版刷OpenWRT保姆级避坑指南:从Python环境到Breed,一次搞定不翻车

小米R4A千兆版OpenWRT刷机全流程精解&#xff1a;零基础到精通的安全实践 第一次接触路由器刷机的用户&#xff0c;往往会被各种专业术语和复杂步骤吓退。作为一款性价比极高的千兆路由器&#xff0c;小米R4A千兆版通过刷入OpenWRT系统可以解锁更多高级功能&#xff0c;但过程中…...

TSF多路调用(Multicall)高级应用:同时处理多个网络请求的性能优化方案

TSF多路调用(Multicall)高级应用&#xff1a;同时处理多个网络请求的性能优化方案 【免费下载链接】tsf coroutine and Swoole based php server framework in tencent 项目地址: https://gitcode.com/gh_mirrors/ts/tsf TSF&#xff08;Tencent Swoole Framework&#…...

从‘内华达州离婚率’到‘A/B测试’:用可交换性思想理解分层模型的底层逻辑

从离婚率到A/B测试&#xff1a;用生活案例理解分层模型的底层逻辑 当内华达州的离婚率遇上统计学 1981年&#xff0c;美国内华达州的离婚率高达每千人13.9例&#xff0c;远高于其他州。这个看似简单的社会现象背后&#xff0c;隐藏着一个深刻的统计学问题&#xff1a;如何理解特…...