我想执行一个进行基本分页的聚合查询:
- 查找属于某个特定的所有订单
company_id
- 订单排序依据
order_number
- 统计文档总数
- 跳至例如文件号码
100
并传递其余的
- 将文档数量限制为例如
2
并将它们传递下去
- 最后返回计数和文档中选定的几个字段
以下是查询的细分:
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"]
},
...
]
}
]
我哪里理解错了?