码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 后端分页应该注意的事项


    分页前应该保证数据的有序性

    在进行分页之前必须保证数据是有一定的顺序的,不能够随机
    如果随机:

    第一次请求第一页时,A数据可能被随机到第一页。当第二次请求时请求第二页,A数据在分页之前可能跑到第二页的数据的位置,此时再进行分页,就会发现本来在第一页出现过的数据A,又在第二页中重复出现。
    很多朋友都会疑问,既然mysql中使用limit之前mysql已经默认排好序了,怎么会出现这个问题呢?
    这时就要注意了,实现分页的方案并不是只有从mysql中使用limit呀。还有一种方法就是直接把全部数据查询出来,在service层中进行分页,所以刚刚这种场景就会出错。
    如何在service层进行分页,可以看我的博客:https://blog.csdn.net/qq_56769991/article/details/125447487


    在工作时,业务要求将查询出来的数据进行分页并随机排序,因为数据量较小,我是直接将全部数据查出来,在service中进行随机排序后,再进行的分页操作,这就造成了数据在第一页和第二页存在数据重复的情况。

    所以在进行分页之前必须保证每个数据在一个确定的位置上,这样才会保证数据不会重复出现。

    那随机排序怎么搞呢?
    在进行分页的情况下,没有整体的乱序,只有局部乱序,即分页后,对当前页进行乱序操作。

    结论:在进行分页操作之前:总体的数据的位置不能改变,否则会在不同页看到相同的数据(除了业务上在数据库插入新数据除外)

    分页后应该保证当前页中的数据数量不变

    分页后的数据,我们可以对分页后的当个数据项内容进行更改,但是千万不要添加新的数据项,否则可能造成"数据丢失"。比如我现在查询到10条数据,现在这边又将两个数据项添加到列表中,变成了12 ,但是前端只要你12条数据,你这被挤出去的2条数据就丢失了,下一页也不会出现你这两条数据。

    结论:千万不要尝试在分页后添加新的数据项,否则会造成数据丢失(除非你有办法把将丢失的数据显示到前端

  • 相关阅读:
    关于城市旅游的HTML网页设计——中国旅游HTML+CSS+JavaScript 出游旅游主题度假酒店 计划出行网站设计
    lambda 的组成部分 operator==类体和全局中的细微区别 哈希容器代码 自定义哈希函数
    【JAVA】泛型
    贝叶斯网络预测相关问题
    sendfile数据copy流程
    多目标最优化的资产配置
    模拟实现Hash-Table(线性探测)
    Alkyne-PEG-OH 炔烃PEG羟基Alkyne-PEG-OH 炔烃PEG羟基
    spring cloud 2021 gateway 报错503 Service Unavailable
    《丞相好梦中杀人,我喜梦中听课》(1)密码学入门
  • 原文地址:https://blog.csdn.net/qq_56769991/article/details/125906704
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号