MongoDB分页排序问题,本页排序与结果集排序

项目中有使用到MongoDB,由于比较高频查询与写入,出现了每次查询的结果集都会变的问题。

描述

我使用的是skip+limit的分页方式,模拟mysql的 limit 0,10去分页
由于出现了结果集变化的问题,我想着使用排序去固定返回的结果集,结果依旧不能如愿。究其原因是因为我的语句顺序问题

//这个aggregating用来分页Aggregation pageAggregation = Aggregation.newAggregation(//查询的字段projectionOperation,//条件Aggregation.match(criteria),Aggregation.group("deviceCode").sum("deviceUseDuration").as("useDuration").count().as("useNumber").last("deviceCode").as("deviceCode"),Aggregation.skip((long) pageNum * pageSize),Aggregation.sort(Sort.Direction.ASC,"deviceCode"),Aggregation.limit(pageSize));

sort()根据deviceCode进行排序,由skip与limit进行分页。
结果sort只能排序当页的数据,原因是sort在skip后面,skip的作用是跳过指定行,先跳过后排序,那么结果肯定不尽人意。

需要将sort放在skip&limit之前。
//这个aggregating用来分页Aggregation.sort(Sort.Direction.ASC,"deviceCode"),Aggregation.skip((long) pageNum * pageSize),Aggregation.limit(pageSize)

mongodb的排序分页是按照流形式去处理数据的,如果是先分页再排序,会导致数据只取前10条,然后在这10条数据里面排序,也就对应前端的效果是排序只对当前页面有效。包括如果使用了统计的方法,如果分页方法在此之前,也会导致先分页在排序的情况出现。因为如果使用了流,分页也会同步使用,尽量在使用流处理之前不分页。

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

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

相关文章

[论文阅读]PV-RCNN++

PV-RCNN PV-RCNN: Point-Voxel Feature Set Abstraction With Local Vector Representation for 3D Object Detection 论文网址:PV-RCNN 论文代码:PV-RCNN 简读论文 这篇论文提出了两个用于3D物体检测的新框架PV-RCNN和PV-RCNN,主要的贡献如下: 提出P…

虚拟机网络没有有效的ip配置

虚拟机网络没有有效的ip配置: 原因猜测:或许是之前使用的操作系统把网络给占了。 解决方法:点击虚拟机的 遍历->网络编辑器->移除不要的网络,然后添加网络。(下面的图就是我把虚拟网络全部移除,然后…

zookeeper:服务器有几种状态?

四种: looking(选举中)、leading(leader)、following( follower)、 observer(观察者角色)

数字图像处理 基于numpy库的傅里叶变换

一、傅里叶变换 图像可以用两个域表示:空间域和频域。空间域是图像最常见的表示形式,其中像素值表示图像中每个点的亮度或颜色。另一方面,频域将图像表示为不同频率和幅度的正弦波的集合。 傅里叶变换(一种图像处理中使用的数学技术)可以通过分析图像的频率分量并揭示隐藏…

4个杀手级Pycharm高效插件

本文将介绍4个学习Python的人都应该安装的Pycharm插件,通过这些插件提高工作效率并使Pycharm看起来更美观。 1、简介 Pycharm是Python最受欢迎的集成开发环境之一。它具有良好的代码助手、漂亮的主题和快捷方式,使编写代码变得简单快捷。 话虽如此&…

Linux进程控制(2)

Linux进程控制(2) 📟作者主页:慢热的陕西人 🌴专栏链接:Linux 📣欢迎各位大佬👍点赞🔥关注🚓收藏,🍉留言 本博客主要内容讲解了进程等待收尾内容和进程的程序…

PTA古风排版

中国的古人写文字&#xff0c;是从右向左竖向排版的。本题就请你编写程序&#xff0c;把一段文字按古风排版。 输入格式&#xff1a; 输入在第一行给出一个正整数N&#xff08;<100&#xff09;&#xff0c;是每一列的字符数。第二行给出一个长度不超过1000的非空字符串&a…

安卓常见设计模式7------适配器模式(Kotlin版)(RecycleView adapter 模板代码)

1. W1 是什么&#xff0c;什么是适配器模式&#xff1f;​ 适配器模式&#xff08;Adapter Pattern&#xff09;是一种常见的设计模式&#xff0c;它用于将一个类的接口转换成另一个客户端所期望的接口。在 Android 中&#xff0c;适配器模式通常用于将数据与视图进行绑定&…

基于若依的ruoyi-nbcio流程管理系统仿钉钉流程json转bpmn的flowable的xml格式(简单支持发起人与审批人的流程)续

更多ruoyi-nbcio功能请看演示系统 gitee源代码地址 前后端代码&#xff1a; https://gitee.com/nbacheng/ruoyi-nbcio 演示地址&#xff1a;RuoYi-Nbcio后台管理系统 之前生产的xml&#xff0c;在bpmn设计里编辑有些内容不正确&#xff0c;包括审批人&#xff0c;关联表单等…

【Linux C IO多路复用】多用户聊天系统

目录 Server-Client mutiplexingServer mutiplexingClient mutiplexing Server-Client 在Linux系统中&#xff0c;IO多路复用是一种机制&#xff0c;它允许一个进程能够监视多个文件描述符&#xff08;sockets、pipes等&#xff09;的可读、可写和异常等事件。这样&#xf…

Linux学习笔记--高级

Shell概述 1&#xff0c;shell概述 是一个c语言编写的脚本语言&#xff0c;是linux和用户的桥梁&#xff0c;用户输入命令交给shell处理。shell&#xff0c;将相应的操作传递给内核&#xff08;kernel&#xff09;&#xff0c;内核把处理的结果输出给用户 1.1Shell解释器有哪…

群辉NAS:ARPL引导黑群晖DSM 7.2详细教程

群辉NAS&#xff1a;ARPL引导黑群晖DSM 7.2详细教程 https://baijiahao.baidu.com/s?id1767784058309148380&wfrspider&forpc

redis持久化和Redis事务

一)Redis持久化之RDBredisDataBase: 什么是持久化: 1)持久性:和持久化说的是同一回事&#xff0c;衡量持久性的前提是重启进程或者是重启主机以后数据是否还存在 持久:把数据存储在硬盘上&#xff0c;那么就是持久性 不持久:把数据存储在内存中 2)redis是一个内存级别的数据库&…

el-table给某一行加背景色

数据列表中总价大于100的一行背景色为红色&#xff0c;效果图如下&#xff1a; 代码示例&#xff1a; <template><div id"app"><!-- 测试区域&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&am…

事务的传播行为、声明式事务和编程式事务、异常失效、事务错误使用、分布式事务

Spring事务详细传播属性解释 Spring事务(Transaction)的传播(propagation)属性以及隔离(isolation)级别 SpringBoot异常处理回滚事务详解(自动回滚、手动回滚、部分回滚&#xff09; 声明式事务和编程式事务 事务传播行为测试 1. Spring事务的传播行为 1. 7种传播行为 事…

leetcode做题笔记2586. 统计范围内的元音字符串数

给你一个下标从 0 开始的字符串数组 words 和两个整数&#xff1a;left 和 right 。 如果字符串以元音字母开头并以元音字母结尾&#xff0c;那么该字符串就是一个 元音字符串 &#xff0c;其中元音字母是 a、e、i、o、u 。 返回 words[i] 是元音字符串的数目&#xff0c;其中…

Cordova插件开发三:通过广播实现应用间跨进程通信

文章目录 1.最终效果预览2.数据发送3.插件接受数据4.JS页面中点击获取数据返回1.最终效果预览 场景说明:我们给自来水公司开发了一个h5应用,需要对接第三方厂家支持硬件设备以便于获取到高精度定位数据,之前几篇文件写过,我已经集成过南方测绘RTK和高精度定位模块的设备,厂…

[unity]切换天空盒

序 unity是自带天空盒的&#xff1a; 但有的时候不想用自带的。怎么自定义&#xff1f;如何设置&#xff1f; 官方文档 Unity - Manual: The Lighting window (unity3d.com) 相关窗口的打开方法 天空盒对应的选项 实际操作 从标准材质球到天空盒材质球 新建一个材质球&…

cookie 里面都包含什么属性?

结论先行&#xff1a; Cookie 中除了名称和值外&#xff0c;还有几个比较常见的&#xff0c;例如&#xff1a; Domain 域&#xff1a;指定了 cookie 可以发送到哪些域&#xff0c;只有发送到指定域或其子域的请求才会携带该cookie&#xff1b; Path 路径&#xff1a;指定哪些…

互联网常见职称

1、管理层 CEO – Chief Executive Officer 首席执行官 VP – Vice President 副总裁 HRD – Humen Resource Director 人力资源总监 OD – Operations Director 运营总监 MD – Marketing Director 市场总监 GM – General Manager 总经理 PM – Production Manager 产品…