$group

聚合 $group 阶段按指定的标识符表达式对文档进行分组,并应用累加器表达式为每个组创建计算字段。 此阶段对于数据聚合和汇总作至关重要。

Syntax

{
  $group: {
    _id: <expression>,
    <field1>: { <accumulator1>: <expression1> },
    <field2>: { <accumulator2>: <expression2> }
  }
}

Parameters

参数 Description
_id Required. 要分组依据的表达式。 使用 null 计算所有输入文档的累积值。
field Optional. 使用累加器运算符(例如$sum、$avg、$max、$min、$count等)进行计算。

例子

请考虑商店集合中的这个示例文档。

{
  "_id": "2cf3f885-9962-4b67-a172-aa9039e9ae2f",
  "name": "First Up Consultants | Bed and Bath Center - South Amir",
  "location": {
    "lat": 60.7954,
    "lon": -142.0012
  },
  "staff": {
    "totalStaff": {
      "fullTime": 18,
      "partTime": 17
    }
  },
  "sales": {
    "totalSales": 37701,
    "salesByCategory": [
      {
        "categoryName": "Mattress Toppers",
        "totalSales": 37701
      }
    ]
  },
  "promotionEvents": [
    {
      "eventName": "Price Drop Palooza",
      "promotionalDates": {
        "startDate": {
          "Year": 2024,
          "Month": 9,
          "Day": 21
        },
        "endDate": {
          "Year": 2024,
          "Month": 9,
          "Day": 30
        }
      },
      "discounts": [
        {
          "categoryName": "Bath Accessories",
          "discountPercentage": 18
        },
        {
          "categoryName": "Pillow Top Mattresses",
          "discountPercentage": 17
        }
      ]
    }
  ]
}

示例 1:按城市分组人员配置分析

此查询按城市对存储进行分组,并分析不同位置的人员配置模式。

db.stores.aggregate([
  {
    $group: {
      _id: "$city",
      totalFullTimeStaff: { $sum: "$staff.employeeCount.fullTime" },
      totalPartTimeStaff: { $sum: "$staff.employeeCount.partTime" },
      avgFullTimeStaff: { $avg: "$staff.employeeCount.fullTime" },
      storesInCity: { $count: {} }
    }
  },
  {
    $project: {
      city: "$_id",
      totalFullTimeStaff: 1,
      totalPartTimeStaff: 1,
      avgFullTimeStaff: { $round: ["$avgFullTimeStaff", 1] },
      storesInCity: 1,
      fullTimeRatio: {
        $round: [
          { $divide: ["$totalFullTimeStaff", { $add: ["$totalFullTimeStaff", "$totalPartTimeStaff"] }] },
          2
        ]
      }
    }
  },
  { $limit : 2}
])

此查询返回的前两个结果为:

[
  {
    "_id": "New Ellsworth",
    "totalFullTimeStaff": 11,
    "totalPartTimeStaff": 1,
    "avgFullTimeStaff": 11,
    "storesInCity": 1,
    "city": "New Ellsworth",
    "fullTimeRatio": 0.92
  },
  {
    "_id": "Jalonborough",
    "totalFullTimeStaff": 4,
    "totalPartTimeStaff": 1,
    "avgFullTimeStaff": 4,
    "storesInCity": 1,
    "city": "Jalonborough",
    "fullTimeRatio": 0.8
  }
]