MongoDB分页实现方式对比:PageRequest vs Skip/Limit

MongoDB分页实现方式对比:PageRequest vs Skip/Limit

    • 一、基本概念
      • 1.1 PageRequest分页
      • 1.2 Skip/Limit分页
    • 二、主要区别
      • 2.1 使用方式
      • 2.2 参数计算
      • 2.3 适用场景
        • PageRequest适用场景:
        • Skip/Limit适用场景:
    • 三、性能考虑
      • 3.1 PageRequest的性能特点
      • 3.2 Skip/Limit的性能特点
    • 四、最佳实践建议
      • 4.1 选择建议
      • 4.2 性能优化建议
      • 4.3 代码示例
        • PageRequest方式:
        • Skip/Limit方式:
    • 五、总结

一、基本概念

1.1 PageRequest分页

PageRequest是Spring Data提供的分页实现,它是基于页码的分页方式(Page-based pagination)。

new PageRequest(page, size)
// page: 页码,从0开始
// size: 每页大小

1.2 Skip/Limit分页

Skip/Limit是MongoDB原生的分页方式,它是基于偏移量的分页(Offset-based pagination)。

query.skip(offset).limit(size)
// offset: 跳过的记录数
// size: 获取的记录数

二、主要区别

2.1 使用方式

  1. PageRequest:
// 获取第一页,每页10条
Pageable pageable = new PageRequest(0, 10);
// 获取第二页,每页10条
Pageable pageable = new PageRequest(1, 10);
  1. Skip/Limit:
// 获取前10条
query.skip(0).limit(10);
// 获取第11-20条
query.skip(10).limit(10);

2.2 参数计算

  1. PageRequest:
page = pageNumber - 1  // pageNumber从1开始
size = pageSize
  1. Skip/Limit:
offset = (pageNumber - 1) * pageSize
limit = pageSize

2.3 适用场景

PageRequest适用场景:
  1. 需要与Spring Data框架深度集成
  2. 需要获取分页的额外信息(总页数、是否是最后一页等)
  3. 数据量较小,页码跨度不大的场景
  4. 用户界面基于页码导航的场景
Skip/Limit适用场景:
  1. 需要更灵活的分页控制
  2. 数据量大,但主要关注连续分页的场景
  3. 无限滚动加载的场景
  4. 需要优化性能的场景

三、性能考虑

3.1 PageRequest的性能特点

  1. 优点:

    • 与Spring Data完美集成
    • 提供丰富的分页信息
    • 代码可读性好
  2. 缺点:

    • 大页码时性能较差
    • 内存占用相对较高
    • 不适合大数据量分页

3.2 Skip/Limit的性能特点

  1. 优点:

    • 实现简单直接
    • 内存占用低
    • 适合大数据量分页
  2. 缺点:

    • skip值较大时性能会下降
    • 不提供总页数等信息
    • 需要自行处理边界情况

四、最佳实践建议

4.1 选择建议

  1. 小型应用,数据量不大:

    • 推荐使用PageRequest,开发更便捷
  2. 大型应用,数据量大:

    • 推荐使用Skip/Limit,性能更好
    • 考虑使用游标或时间戳分页

4.2 性能优化建议

  1. 添加适当的索引
  2. 避免大的偏移量
  3. 考虑使用游标分页
  4. 合理设置每页大小

4.3 代码示例

PageRequest方式:
public List<MetadataPO> findByPage(String appId, int page, int size) {Pageable pageable = new PageRequest(page, size);Query query = new Query().with(pageable);return mongoTemplate.find(query, MetadataPO.class);
}
Skip/Limit方式:
public List<MetadataPO> findByOffset(String appId, int offset, int size) {Query query = new Query();query.skip(offset).limit(size);return mongoTemplate.find(query, MetadataPO.class);
}

五、总结

  1. PageRequest和Skip/Limit各有优势,选择时需要考虑:

    • 数据量大小
    • 性能要求
    • 业务场景
    • 开发便利性
  2. 实际应用建议:

    • 数据量<10万,用户习惯页码翻页:选择PageRequest
    • 数据量>10万,或需要无限滚动:选择Skip/Limit
    • 数据量>100万:考虑使用游标分页
  3. 性能优化核心:

    • 合理使用索引
    • 避免大偏移量
    • 控制每页数据量
    • 考虑缓存策略

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/72143.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Manus(一种AI代理或自动化工具)与DeepSeek(一种强大的语言模型或AI能力)结合使用任务自动化和智能决策

一、Manus与DeepSeek差异 十分好奇DeepSeek和Manus究竟谁更厉害些&#xff0c;DeepSeek是知识型大脑&#xff0c;Manus则是全能型执行者。即DeepSeek专注于语言处理、知识整合与专业文本生成。其核心优势在于海量参数支持的深度学习和知识推理能力&#xff0c;例如撰写论文、润…

UI自动化:poium测试库

以下是关于 poium 测试库 的详细介绍&#xff0c;涵盖其核心功能、使用方法及与原生 Selenium 的对比&#xff0c;帮助快速掌握这一工具&#xff1a; 1. poium 简介 定位&#xff1a;基于 Selenium 的 Page Object 模式增强库&#xff0c;专注于简化元素定位和页面操作。 核心…

C#结构体(Struct)详解

在 C# 中&#xff0c;‌结构体&#xff08;struct&#xff09;‌ 是一种值类型数据类型&#xff0c;适用于封装小型数据组。与类&#xff08;class&#xff09;不同&#xff0c;结构体在栈&#xff08;Stack&#xff09;上分配内存&#xff0c;且赋值时会发生值复制。以下是结构…

UVC摄像头命令推流,推到rv1126里面去

ffmpeg命令查询UVC设备 .\ffmpeg.exe -list_devices true -f dshow -i dummy 上图是查询UVC设备的效果图&#xff0c;画红框的部分是UVC设备的设备名称"USB2.0 PC CAMERA"和设备号 "device_pnp_\\?\usb#vid_1908&pid_2310&mi_00#8&39abfe5&0&a…

Linux中的基本指令(上)

目录 ls指令 判断linux中文件 pwd指令 认识路径 ​编辑 绝对路径/相对路径 cd指令 简要理解用户 理解家目录 echo指令和printf指令 touch指令 mkdir指令 cat指令 tree指令 rmdir指令和rm指令 man指令 cp指令 which指令 alias 指令 date指令 cal指令 理解…

多数元素——面试经典150题(力扣)

题目 给定一个大小为 n 的数组 nums &#xff0c;返回其中的多数元素。多数元素是指在数组中出现次数 大于 ⌊ n/2 ⌋ 的元素。 你可以假设数组是非空的&#xff0c;并且给定的数组总是存在多数元素。 示例 1&#xff1a; 输入&#xff1a;nums [3,2,3] 输出&#xff1a;3 …

Qt 数据库操作(Sqlite)

数据库简介 关于数据库的基础知识这里就不做介绍了&#xff0c;相关博客可以查看&#xff1a; SQL基础知识 数据库学霸笔记 上面博客都写的比较详细&#xff0c;本文主要介绍如何使用Qt进行数据库相关操作&#xff0c;数据库分为关系型数据库和非关系型数据&#xff0c;关系…

网络安全 api 网络安全 ast技术

随着应用或者API被攻击利用已经越来越多&#xff0c;虽然来自开源组件的漏洞加剧了这一现象的发生&#xff0c;但是&#xff0c;其实主要还是在于应用程序或者API本身没有做好防范&#xff0c;根源在于源代码本身的质量没有严格把控。AST是指Application Security Testing&…

Mac 配置 Maven JDK

不使用 Homebrew&#xff0c;创建指定版本 JDK 1、官网下载指定版本并安装……省略 2、vi &#xff5e;/.zshrc 同时要检查 bash_profile 是否存在。 if [ -f ~/.bash_profile ] ; thensource ~/.bash_profile fiJAVA_HOME_11/Library/Java/JavaVirtualMachines/jdk-11.0.1…

【每日学点HarmonyOS Next知识】拖拽调整列表顺序、tab回弹、自定义弹窗this、状态变量修饰枚举

1、HarmonyOS 功能实现&#xff08;拖拽调整列表顺序&#xff09;&#xff1f; 可参考&#xff1a; import curves from ohos.curves; import Curves from ohos.curvesEntry Component struct ListItemExample {State private arr: number[] [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]…

Django部署Filemanagement

Pycharm搭建项目安装虚拟环境 mysqlclient对mysql的安装&#xff0c;配置有要求 pymsql伪装成mysqlclient&#xff0c;pymysql可以操纵mysql pip install pymysql操作sql5.7 mysql8.0会出现与pycharm不兼容问题&#xff0c;会报错&#xff0c;所以降到5.7 # 进入mysql 需要…

【病毒分析】熊猫烧香病毒分析及其查杀修复

目录 前言 一、样本概况 1.1 样本信息 1.2 测试环境及工具 1.3 分析目标 二、具体行为分析 2.1 主要行为 2.1.1 恶意程序对用户造成的危害 2.2 恶意代码分析 2.2.1 加固后的恶意代码树结构图(是否有加固) 2.2.2 恶意程序的代码分析片段 三、解决方案(或总结) 3.1 …

Spring Boot集成Spring Statemachine

Spring Statemachine 是 Spring 框架下的一个模块&#xff0c;用于简化状态机的创建和管理&#xff0c;它允许开发者使用 Spring 的特性&#xff08;如依赖注入、AOP 等&#xff09;来构建复杂的状态机应用。以下是关于 Spring Statemachine 的详细介绍&#xff1a; 主要特性 …

数组总和 (leetcode 40

leetcode系列 文章目录 一、核心操作二、外层配合操作三、核心模式代码总结 去重方式和之前三数之和一样&#xff0c;也可以用used数组去重&#xff0c;但本次尝试使用set去重 一、核心操作 如果count为0了&#xff0c;则证明正好减到了0&#xff0c;就可以收获&#xff0c;…

sqli-lab靶场学习(八)——Less26-28

前言 25关已经出现了初步的一些关键字过滤&#xff0c;通过双写可以绕过。后面的关卡&#xff0c;我们会遇到更多关键字过滤&#xff0c;需要各种技巧绕过。 Less26 第26关写了会过滤空格和注释符。有很多的答案&#xff0c;会用%a0替代空格&#xff0c;但据说这是sqli-labs部…

python:VOC格式数据集转换为YOLO数据集格式

作者&#xff1a;CSDN _养乐多_ 本文将介绍如何将目标检测中常用的VOC格式数据集转换为YOLO数据集&#xff0c;并进行数据集比例划分&#xff0c;从而方便的进行YOLO目标检测。 如果不想分两步&#xff0c;可以直接看第三节代码。 文章目录 一、将VOC格式数据集转换为YOLO格…

Docker容器安装软件(完整版)

文章目录 一、安装Docker1.1 docker 相关的命令1.2 配置镜像加速 二. 安装es2.1 创建网络2.2 拉取镜像2.3 创建挂载点目录2.4 部署单点es&#xff0c;创建es容器2.5 编写elasticsearch.yml2.6 重启es容器2.7 测试Elasticsearch是否安装成功 三. 基于Docker安装Kibana3.1 拉取镜…

LINUX 指令大全

Linux服务器上有许多常用的命令&#xff0c;可以帮助你管理文件、目录、进程、网络和系统配置等。以下是一些常用的Linux命令&#xff1a; 文件和目录管理 ls&#xff1a;列出当前目录中的文件和子目录 bash lspwd&#xff1a;显示当前工作目录的路径 bash pwdcd&#xff1a;切…

燃气对我们生活的重要性体现在哪里?

燃气在我们的生活中有 多方面的重要性 &#xff0c;以下是燃气对我们生活的重要性的详细说明&#xff1a; 烹饪和热水供应 &#xff1a; 燃气是家庭烹饪的主要能源&#xff0c;能够快速、高效地加热食物&#xff0c;使家庭聚餐更加便捷和愉快。 燃气热水器能够在短时间内提供…

NetAssist 5.0.14网络助手基础使用及自动应答使用方案

以下是NetAssist v5.0.14自动应答功能的详细使用步骤&#xff1a; 一、基础准备&#xff1a; 工具下载网址页面&#xff1a;https://www.cmsoft.cn/resource/102.html 下载安装好后&#xff0c;根据需要可以创建多个server&#xff0c;双击程序图标运行即可&#xff0c;下面…