文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

分页查询出现重复数据

2023-09-12 20:49

关注

目录

问题描述

问题表现 

问题原因 

解决方法


问题描述

问题表现 

第一页请求参数如下:

返回数据如下:

 第二页请求参数如下:

 返回数据如下:

有一条数据缺失了,即: 

 

问题原因 

经查询数据库表,该数据确实存在
那明显就是业务实现有误。
2.对业务实现sql进行排查并测试,发现最终原因是排序导致。

实现代码如下:

$data = $conn->skip($offSet)->take($count)->orderBy('is_expire', 'desc')->orderBy('overtime', 'asc')->getArray($key);

 这一类的问题,隐藏比较隐秘,即当is_expire,overtime这两个参数都相等的多条数据存在时,

才会出现数据重复显示问题。数据表查询没有一个决定性的排序条件,多条数据比较条件一致,

则会认为返回哪个都一样,最终就出现第一二页有一条重复数据。

解决方法

在排序的两个条件之后,在加一条决定性的排序条件,使每一条数据都是唯一的,这样就不会有数据被覆盖情况出现。
实现代码如下:

$data = $conn->skip($offSet)->take($count)->orderBy('is_expire', 'desc')->orderBy('overtime', 'asc')->orderBy('id', 'asc') # 增加id排序->getArray($key);

 在这里记录一下,以备查阅,毕竟好记性不如烂笔头。虽然问题解决容易,但是不暴露也无法解决,尤其当一个业务没有问题且需求不变的时候,我们通常不会去查看它,还是从平时开发时注意细节入手吧。

来源地址:https://blog.csdn.net/json_ligege/article/details/128499204

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯