gpt4 book ai didi

mongodb - 如何使用MongoDB聚合进行分页?

转载 作者:可可西里 更新时间:2023-11-01 09:06:55 25 4
gpt4 key购买 nike

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

  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

例如显示第3页,每页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
} }
] )

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

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

关于mongodb - 如何使用MongoDB聚合进行分页?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48305624/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com