我想执行一个进行基本分页的聚合查询:

  1. 查找属于某个company_id的所有订单
  2. order_number对订单进行排序
  3. 计算文档总数
  4. 跳转到例如文件编号100,并将其传递给其他人
  5. 将文档数量限制为2个,并将其传递
  6. 通过返回计数和文档中选定的几个字段来完成

以下是查询的详细信息:

db.Order.collection.aggregate([

这将查找所有匹配的文档:

  { '$match'    : { "company_id" : ObjectId("54c0...") } },

这将对文档进行排序:

  { '$sort'     : { 'order_number' : -1 } },

这会对文档进行计数,并传递未修改的文档,但我肯定这样做是错误的,因为事情从这里开始变得很奇怪:

  {
    '$group' : {
      '_id'     : null,
      'count'   : { '$sum' : 1 },
      'entries' : { '$push' : "$$ROOT" }
    }
  },

这似乎跳过了一些文档:

  { "$skip"     : 100 },

这本应限制文件,但却没有:

  { "$limit"    : 2 },

这会返回计数,但不会返回数组中的文档,而是返回每个字段的数组:

  { '$project'  : {
      'count'     : 1,
      'entries'   : {'_id' : "$entries._id", 'order_number' : "$entries.order_number"}
    }
  }
])

结果是:

[
  { "_id" : null,
    "count" : 300,
    "entries" : [
      {
        "_id" : [ObjectId('5a5c...'), ObjectId('5a5c...')],
        "order_number" : ["4346", "4345"]
      },
      {
        "_id" : [ObjectId('5a5c...'), ObjectId('5a5c...')],
        "order_number" : ["4346", "4345"]
      },
      ...
    ]
  }
]

我哪里弄错了?

推荐答案

要计算返回的子集,需要对同一数据集应用分组和跳过/限制.为此,你可以使用facets

例如,要显示第三页,每页10个文档:

db.Order.aggregate([
    { '$match'    : { "company_id" : ObjectId("54c0...") } },
    { '$sort'     : { 'order_number' : -1 } },
    { '$facet'    : {
        metadata: [ { $count: "total" }, { $addFields: { page: NumberInt(3) } } ],
        data: [ { $skip: 20 }, { $limit: 10 } ] // add projection here wish you re-shape the docs
    } }
] )

它将返回一个包含两个字段的文档:

{
    "metadata" : [ 
        {
            "total" : 300,
            "page" : 3
        }
    ],
    "data" : [ 
        {
            ... original document ...
        }, 
        {
            ... another document ...
        }, 
        {
            ... etc up to 10 docs ...
        }
    ]
}

Mongodb相关问答推荐

Spring Data MongoDB中的@ Transactions(+测试容器)

MongoDB:就地分组嵌套数组的元素

数组字段包含其他字段的数组值

MongoDB MQL,将列表一分为二,仅获取唯一值

MongoDB - 将数组元素转换为新字段

MongoDB 聚合 groupBy 日期并计算子文档

如何在 MongoDB 中已经存在的 slug 中添加一个随机数?

MongoDB 的 Java 语法

指定字段对于 MongoDB 是transient瞬态的,但对于 RestController 不是

Mongo 重启错误 -- /var/run/mongodb/mongod.pid 存在

如何在任意深度查找 MongoDB 字段名称

NodeJS中的密码重置

如何在 mongo JavaScript shell 中中止查询

Mongoose 中不同集合的相同模式

mongoose得到`TypeError: user.save is not a function` - 出了什么问题

mongo - Ruby连接问题

使用 mongodb 在数组中查找子文档

mongoosefind()不返回结果

MongoError:failed to connect to server [localhost:27017] on first connect

Mongodb 查找除一两个条件之外的所有内容