| 注册
请输入搜索内容

热门搜索

Java Linux MySQL PHP JavaScript Hibernate jQuery Nginx
jopen
10年前发布

MongoDB实现分页(两种方法)

1.插入实验数据

偷懒用下samus,100条。

for (int i = 0; i < 100; i++)                  {                      Document doc = new Document();                      doc["ID"] = i;                      doc["Msg"] = "value is "+ i;                      mongoCollection.Insert(doc);                  }

插入成功

 MongoDB实现分页(两种方法)

2.分页

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

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

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

 MongoDB实现分页(两种方法)

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

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

 MongoDB实现分页(两种方法)

3.两种方法的比较

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

来自:http://www.cnblogs.com/linhan/p/4248679.html

 本文由用户 jopen 自行上传分享,仅供网友学习交流。所有权归原作者,若您的权利被侵害,请联系管理员。
 转载本站原创文章,请注明出处,并保留原始链接、图片水印。
 本站是一个以用户分享为主的开源技术平台,欢迎各类分享!
 本文地址:https://www.open-open.com/lib/view/open1422197230531.html
MongoDB NoSQL数据库