首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Skip MongoDb后计数

Skip MongoDb后计数
EN

Stack Overflow用户
提问于 2014-10-10 21:07:16
回答 2查看 142关注 0票数 0

我有这样的收藏品

代码语言:javascript
复制
{
    "_id" : ObjectId("54368d9125c3dc7c1f43295f"),
    "nome" : "John",
    "eta" : 30,
    "data" : ISODate("2014-10-09T10:30:00.000Z")
}


{
    "_id" : ObjectId("54368d9c25c3dc7c1f432960"),
    "nome" : "Paul",
    "eta" : 31
}

我做这个查询

代码语言:javascript
复制
db.coll.find({eta:{$gt:30}})

我的结果是一份文件(保罗)

代码语言:javascript
复制
db.coll.find({eta:{$gt:30}}).count() //1

如果我做了

代码语言:javascript
复制
db.coll.find({eta:{$gt:30}}).skip(1) 

我还没有结果,没事的。但如果我这么做

代码语言:javascript
复制
db.coll.find({eta:{$gt:30}}).skip(1).count() 

我的结果是1

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-10-10 21:23:19

来自count()的文档

默认情况下,count()方法忽略cursor.skip()和cursor.limit()的效果。将applySkipLimit设置为true,以考虑这些方法的效果。

因此,如果希望考虑skip()的影响,可以提供一个名为applySkipLimit的可选参数,如下所示:

代码语言:javascript
复制
db.coll.find({eta:{$gt:30}}).skip(1).count({applySkipLimit:1}); 

或者简单的

代码语言:javascript
复制
db.coll.find({eta:{$gt:30}}).skip(1).count(true); 
票数 2
EN

Stack Overflow用户

发布于 2014-10-10 21:20:07

使用size而不是count,因为它包含了游标上任何skiplimit调用的效果:

代码语言:javascript
复制
db.coll.find({eta:{$gt:30}}).skip(1).size() 
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26308046

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档