您当前的位置: 首页 >  mongodb

qq_34412985

暂无认证

  • 0浏览

    0关注

    1061博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

mongoDB分页查询

qq_34412985 发布时间:2019-01-26 18:22:05 ,浏览量:0

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方法效率较低,在数据量较多的情况下更推荐使用方法二,但可能会占用较多的内存空间。

关注
打赏
1653291990
查看更多评论
立即登录/注册

微信扫码登录

0.0459s