首页 > 代码库 > MongoDB实现分页(两种方法)
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方法效率较低,在数据量较多的情况下更推荐使用方法二,但可能会占用较多的内存空间。
MongoDB实现分页(两种方法)
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。