MongoDB 使用Skip和limit分页

 更新时间:2014年08月25日 12:02:44   投稿:hebedich  
本文章先来给大家简单介绍关于MongoDB 数据分页和排序 limit,skip用户的一些基础语句,然后用一个实例详细介绍MongoDB 数据分页和排序实例方法。

使用Skip和limit可以如下做数据分页:

Code:

   page1 = db.things.find().limit(20)
   page2 = db.things.find().skip(20).limit(20)
   page3 = db.things.find().skip(40).limit(20) 

  备注:可用于分页,limit是pageSize,skip是第n-1页*pageSize (n-1表示几  第1,2...页)      skip表示跳过  多少条数据,   聚合管道的优化
     1.$sort  +  $skip  +  $limit顺序优化

    如果在执行管道聚合时,如果$sort、$skip、$limit依次出现的话,例如:

    { $sort: { age : -1 } },
    { $skip: 10 },
    { $limit: 5 }

    那么实际执行的顺序为:

{ $sort: { age : -1 } },
    { $limit: 15 },
    { $skip: 10 }

    $limit会提前到$skip前面去执行。

    此时$limit = 优化前$skip+优化前$limit

    这样做的好处有两个:

    1.在经过$limit管道后,管道内的文档数量个数会“提前”减小,这样会节省内存,提高内存利用效率。

    2.$limit提前后,$sort紧邻$limit这样的话,当进行$sort的时候当得到前“$limit”个文档的时候就会停止。

    当数据量很小时,这样做分页完全没有问题。但是当数据量很大时,skip操作会变的很慢,应该避免使用。  

(不止是mongoDb会这样,大部分数据库都是。)可以通过改变查询文档的规则来达到分页效果,避免使用skip来跳过大量的数据。

(通过计算,得到下次查询应该从什么地方开始)

相关文章

  • 批量清理mongodb历史数据的方法详解

    批量清理mongodb历史数据的方法详解

    这篇文章主要介绍了批量清理 MongoDB 历史数据的相关内容,包括项目因历史数据积压需清理,从临时 shell 脚本改为用 Python 改造,新增备份功能和配置文件,还详细介绍了多个相关函数的定义及功能,需要的朋友可以参考下
    2025-01-01
  • mongoDB4.2.8备份恢复与导出导入(推荐)

    mongoDB4.2.8备份恢复与导出导入(推荐)

    这篇文章主要介绍了mongoDB4.2.8备份恢复与导出导入的相关知识,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-12-12
  • MongoDB的基础知识简介

    MongoDB的基础知识简介

    这篇文章主要介绍了MongoDB的基础知识简介,需要的朋友可以参考下
    2017-05-05
  • 优化MongoDB配置来提高CPU使用率

    优化MongoDB配置来提高CPU使用率

    MongoDB作为NoSQL数据库的一种,已经成为新一代数据存储系统的趋势,然而,MongoDB数据服务的性能问题一直是亟待解决的关键问题之一,在许多基于MongoDB的利用中,CPU利用率是一个重要的指标,它可以帮助我们对服务器的性能进行实时监控,以便及时发现和修复效力瓶颈
    2024-01-01
  • MongoDB与MySQL常用操作语句对照

    MongoDB与MySQL常用操作语句对照

    这篇文章主要介绍了MongoDB与MySQL常用操作语句对照,本文整合了两篇博文,相信最常用的操作都收录在本文了,需要的朋友可以参考下
    2015-05-05
  • MongoDB的基本操作实例详解【服务端启动,客户端连接,CRUD操作】

    MongoDB的基本操作实例详解【服务端启动,客户端连接,CRUD操作】

    这篇文章主要介绍了MongoDB的基本操作,结合实例形式分析了MongoDB数据库的服务端启动,客户端连接,CRUD操作等基本实现方法与操作注意事项,需要的朋友可以参考下
    2020-04-04
  • Java操作MongoDB数据库方法详解

    Java操作MongoDB数据库方法详解

    本文给大家分享的是使用Java操作MongoDB的一些基本方法,包含多种数据库的连接方式,增删改查等方法,非常的实用,有需要的小伙伴可以参考下
    2018-01-01
  • MongoDB的mongo shell常用操作方法及操作脚本笔记

    MongoDB的mongo shell常用操作方法及操作脚本笔记

    mongo shell即相当于SQL语句在关系型数据库中的作用,MongoDB使用JavaScript作为shell操作命令,这里我们就来整理MongoDB的mongo shell常用操作方法及操作脚本笔记
    2016-07-07
  • mongodb三分钟入门大全

    mongodb三分钟入门大全

    MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的,接下来通过本文给大家介绍mongodb三分钟入门大全,感兴趣的朋友一起看看吧
    2022-01-01
  • MongoDB 删除文档的方式(删除一个、批量删除)

    MongoDB 删除文档的方式(删除一个、批量删除)

    这篇文章主要介绍了MongoDB 删除文档的方式(删除一个、批量删除),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-04-04

最新评论