zoukankan      html  css  js  c++  java
  • MongoDB实现分页(两种方法)

    1.插入实验数据

    偷懒用下samus,100条。

    1                 for (int i = 0; i < 100; i++)
    2                 {
    3                     Document doc = new Document();
    4                     doc["ID"] = i;
    5                     doc["Msg"] = "value is "+ i;
    6                     mongoCollection.Insert(doc);
    7                 }

    插入成功

    2.分页

    方法一:通过sike()与limit()方法 如下图,

    通过 db.myCollection.find().sort({"ID":1}).skip(10).limit(10)命令,将其根据ID排序后,跳过10,查询10条,结果为10-19条的数据。

    这个类似于EF框架下的Skip()和Take()方法的操作。

    方法二:获取前一页的最后一条记录,查询之后的指定条记录 如下图,

    在tmp中存储前面的10条记录,latest中存储前一页的最后一条记录(第9条),在接下去的查询中,通过find后的参数,过滤去之前的记录,获取之后的10条记录。

    3.两种方法的比较

    方法一比较简单,但skip方法效率较低,在数据量较多的情况下更推荐使用方法二,但可能会占用较多的内存空间。

  • 相关阅读:
    java-初始化和清理
    java-字符串
    java-I/O流
    java-反射和代理
    java-执行流程控制语句
    java-访问控制修饰符
    java-异常
    java-注解
    [ Java学习 ] 一道Java好题的详细题解 001
    [ Java学习 ] 查阅资料整理 002
  • 原文地址:https://www.cnblogs.com/linhan/p/4248679.html
Copyright © 2011-2022 走看看