MongoDB分组聚合查询

MongoDB group by aggregation query

我的数据是:

[
    { type: 'software' },
    { type: 'hardware' },
    { type: 'software' },
    { type: 'network' },
    { type: 'test' },
    ...
]

我想通过聚合管道创建一个 MongoDB 组到 return 数据,如下所示: 结果我只想要 3 个对象 结果中的第三个对象 {_id: 'other', count: 2}, 这应该是软件和硬件

以外类型的计数总和
[
    {_id: 'software', count: 2},
    {_id: 'hardware', count: 1},
    {_id: 'other', count: 2},
]

这是the exact query (MongoPlayground) that you need if those data are separate documents. Just add $project stage before group and then $switch operator. (If those field data are number, you might wanna check $bucket

db.collection.aggregate([
  {
    "$project": {
      type: {
        "$switch": {
          "branches": [
            {
              "case": {
                "$eq": [
                  "$type",
                  "software"
                ]
              },
              "then": "software"
            },
            {
              "case": {
                "$eq": [
                  "$type",
                  "hardware"
                ]
              },
              "then": "hardware"
            }
          ],
          default: "other"
        }
      }
    }
  },
  {
    "$group": {
      "_id": "$type",
      "count": {
        "$sum": 1
      }
    }
  }
])

Also, I'd like to recommend avoiding field name type. Actually it doesn't reserve in MongoDB, but however it could bring conflicts with some drivers since, in schema/model files, type fields are referred to the exact BSON type of the field.