做实验验证MongoDB分页的两种方法

本文介绍了两种在MongoDB中实现高效分页查询的方法。第一种方法直接利用skip和limit函数进行分页;第二种方法通过记录最后一条已知数据进行查询,避免使用skip提高效率。适用于不同数据量场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

下面是我的测试方法:
> db.chenfeng.save({age:1,name:"duansf"})
WriteResult({ "nInserted" : 1 })
> db.chenfeng.save({age:2,name:"duansf"})
WriteResult({ "nInserted" : 1 })
> db.chenfeng.save({age:3,name:"duansf"})
WriteResult({ "nInserted" : 1 })
> db.chenfeng.save({age:4,name:"duansf"})
WriteResult({ "nInserted" : 1 })
> db.chenfeng.save({age:5,name:"duansf"})
WriteResult({ "nInserted" : 1 })
> db.chenfeng.save({age:6,name:"duansf"})
WriteResult({ "nInserted" : 1 })
> db.chenfeng.find()
{ "_id" : ObjectId("5714419cf7c81959e12a904e"), "age" : 1, "name" : "duansf" }
{ "_id" : ObjectId("571441a3f7c81959e12a904f"), "age" :  2, "name" : "duansf" }
{ "_id" : ObjectId("571441a7f7c81959e12a9050"), "age" : 3, "name" : "duansf" }
{ "_id" : ObjectId("571441abf7c81959e12a9051"), "age" : 4, "name" : "duansf" }
{ "_id" : ObjectId("571442b0f7c81959e12a9052"), "age" : 5, "name" : "duansf" }
{ "_id" : ObjectId("571442bcf7c81959e12a9053"), "age" : 6, "name" : "duansf" }
>


第一种方法
查询第一页的数据(按两条数据为一页)
> db.chenfeng.find().sort({"age":1}).limit(2);
{ "_id" : ObjectId("5714419cf7c81959e12a904e"), "age" : 1, "name" : "duansf" }
{ "_id" : ObjectId("571441a3f7c81959e12a904f"), "age" : 2, "name" : "duansf" }
>

查询第二页的数据:
> db.chenfeng.find().sort({"age":1}).skip(2).limit(2);
{ "_id" : ObjectId("571441a7f7c81959e12a9050"), "age" : 3, "name" : "duansf" }
{ "_id" : ObjectId("571441abf7c81959e12a9051"), "age" : 4, "name" : "duansf" }
>

查询第三页的数据:
> db.chenfeng.find().sort({"age":1}).skip(4).limit(4);
{ "_id" : ObjectId("571442b0f7c81959e12a9052"), "age" : 5, "name" : "duansf" }
{ "_id" : ObjectId("571442bcf7c81959e12a9053"), "age" : 6, "name" : "duansf" }
>


第二种方法:
查询第一页的数据:
> db.chenfeng.find().sort({"age":1}).limit(2);
{ "_id" : ObjectId("5714419cf7c81959e12a904e"), "age" : 1, "name" : "duansf" }
{ "_id" : ObjectId("571441a3f7c81959e12a904f"), "age" : 2, "name" : "duansf" }
>


查询第二页和第三页的数据:
> var c1=db.chenfeng.find().sort({"age":1}).limit(2);
> var latest=null;
> while(c1.hasNext()){
... latest=c1.next();
... }
{
        "_id" : ObjectId("571441a3f7c81959e12a904f"),
        "age" : 2,
        "name" : "duansf"
}
> db.chenfeng.find({"age":{"$gt":latest.age}}).sort({"age":1}).limit(2);
{ "_id" : ObjectId("571441a7f7c81959e12a9050"), "age" : 3, "name" : "duansf" }
{ "_id" : ObjectId("571441abf7c81959e12a9051"), "age" : 4, "name" : "duansf" }

> db.chenfeng.find({"age":{"$gt":latest.age}}).sort({"age":1}).limit(4);
{ "_id" : ObjectId("571441a7f7c81959e12a9050"), "age" : 3, "name" : "duansf" }
{ "_id" : ObjectId("571441abf7c81959e12a9051"), "age" : 4, "name" : "duansf" }
{ "_id" : ObjectId("571442b0f7c81959e12a9052"), "age" : 5, "name" : "duansf" }
{ "_id" : ObjectId("571442bcf7c81959e12a9053"), "age" : 6, "name" : "duansf" }
>


总结来说,如果数据量不是很大的话,可以使用第一种方法,毕竟比较简单,如果数据量比较大的话,使用第二种方法比较好,
因为这样就可以不用到skip()这个函数,skip跳过太多的记录,效率有点低

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/15498/viewspace-2083154/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/15498/viewspace-2083154/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值