mongodb - 如何在 $group 阶段后返回所有字段而不指定

标签 mongodb mongodb-query aggregation-framework

如何对文档中的子数组进行排序并保留父字段? 我有一个这样的集合:

{ 
    "_id" : ObjectId("5d1757929831633ff8abb638"), 
    "name" : "Carraro Exlusive", 
    "description" : "Carraro Exlusive description", 
    "image" : "image-15", 
    "__v" : 0, 
    "sellers" : [
        {
            "_id" : ObjectId("5d1757929831633ff8abb639"), 
            "product" : ObjectId("5d1757929831633ff8abb638"), 
            "seller" : ObjectId("5d1518582f9254189ca92e59"), 
            "price" : 13, 
            "stock" : 5, 
            "__v" : 0
        }, 
        {
            "_id" : ObjectId("5d175b60cf85a22f745235ee"), 
            "product" : ObjectId("5d1757929831633ff8abb638"), 
            "seller" : ObjectId("5d164802c4dc7811b0f34b86"), 
            "price" : 10, 
            "stock" : 222, 
            "__v" : 0
        }
    ]
}

我想按价格从小到大对内部卖家数组进行排序。

我想要的结果是:

{ 
    "_id" : ObjectId("5d1757929831633ff8abb638"), 
    "name" : "Carraro Exlusive", 
    "description" : "Carraro Exlusive", 
    "category" : ObjectId("5d151ad1b72c830f14374bb4"), 
    "brand" : ObjectId("5d151981b72c830f14374bb2"), 
    "image" : "image-15", 
    "__v" : 0, 
    "sellers" : [
     {
            "_id" : ObjectId("5d175b60cf85a22f745235ee"), 
            "product" : ObjectId("5d1757929831633ff8abb638"), 
            "seller" : ObjectId("5d164802c4dc7811b0f34b86"), 
            "price" : 10, 
            "stock" : 222, 
            "__v" : 0
        },
        {
            "_id" : ObjectId("5d1757929831633ff8abb639"), 
            "product" : ObjectId("5d1757929831633ff8abb638"), 
            "seller" : ObjectId("5d1518582f9254189ca92e59"), 
            "price" : 13, 
            "stock" : 5, 
            "__v" : 0
        }
    ]
}

我看到了下面的帖子,但我想保留父字段: Mongodb sort inner array

最佳答案

您可以使用以下聚合

db.collection.aggregate([
  { "$unwind": "$sellers" },
  { "$sort": { "sellers.price": 1 }},
  { "$group": {
    "_id": "$_id",
    "sellers": { "$push": "$sellers" },
    "allFields": { "$first": "$$ROOT" }
  }},
  { "$replaceRoot": {
    "newRoot": {
      "$mergeObjects": [
        "$allFields",
        { "sellers": "$sellers" }
      ]
    }
  }}
])

关于mongodb - 如何在 $group 阶段后返回所有字段而不指定,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56915860/

相关文章:

c# - MapReduce输出C#读取mongoDB

node.js - 聚合组上的 Mongoose 错误

MongoDB count with query 返回的记录多于 count all

MongoDB - 获取不同级别字段之间的$max

mongodb - $filter 嵌套级别与 $or、$gte、$lte 运算符

ruby-on-rails - 我如何从 Ruby 代码连接到 mongodb?

mysql - 如何找到 MongoDB 字典中出现次数最多的字段?

node.js - 将 Bluebird 用于 Mongoose ,得到 ".bind is not a function"

mongodb - 按不同权重的相关性查询

MongoDB:使用来自多个集合的数据进行过滤