MongoDB 聚合:按类别分组并汇总金额

MongoDB aggregation : Group by Category and sum up the amount

我的 collection 中有以下结构(您不必介意状态):

{
    "_id": {
        "$oid": "5e6355e71b14ee00175698cb"
    },
    "finance": {
        "expenditure": [
            {
                "status": true,
                "_id": { "$oid": "5e63562d1b14ee00175698df" },
                "amount": { "$numberInt": "100" },
                "category": "Sport"
            },
            {
                "status": true,
                "_id": { "$oid": "5e6356491b14ee00175698e0" },
                "amount": { "$numberInt": "200" },
                "category": "Sport"
            },
            {
                "status": true,
                "_id": { "$oid": "5e63565b1b14ee00175698e1" },
                "amount": { "$numberInt": "50" },
                "category": "Outdoor"
            },
            {
                "status": true,
                "_id": { "$oid": "5e63566d1b14ee00175698e2" },
                "amount": { "$numberInt": "400" },
                "category": "Outdoor"
            }
        ]
    }
}

我之前的命令是这样的:

User.aggregate([
    { $match: {_id: req.user._id} },
    { $unwind: '$finance.expenditure' },
    { $match: {'finance.expenditure.status': true} },
    { $sort: {'finance.expenditure.currentdate': -1} },
    {
        $group: {
            _id: '$_id',
            expenditure: { $push: '$finance.expenditure' }
        }
    }
])

有了这个我就把每一笔支出都拿回来了。

但现在我想按类别对支出进行分组,然后汇总每组支出的金额。

所以它应该是这样的:

{ "amount": 300 }, "category": "Sport" },
{ "amount": 450 }, "category": "Outdoor" }

感谢您的帮助

而不是在 _id 字段上分组 在类别字段和总金额字段上分组:

db.collection.aggregate([
  { $match: {_id: req.user._id}},
  {
    $unwind: "$finance.expenditure"
  },
  {
    $match: {
      "finance.expenditure.status": true
    }
  },
  {
    $sort: {
      "finance.expenditure.currentdate": -1
    }
  },
  {
    $group: {
      _id: "$finance.expenditure.category",
      amount: {
        $sum: "$finance.expenditure.amount"
      }
    }
  },
  {
    $project: {
      _id: 0,
      category: "$_id",
      amount: 1
    }
  }
])

测试: MongoDB-Playground