Compartir a través de


agregado

El aggregate comando se usa para procesar registros de datos y devolver resultados calculados. Realiza operaciones en los datos, como el filtrado, la agrupación y la ordenación, y puede transformar los datos de varias maneras. El aggregate comando es muy versátil y se usa normalmente para el análisis de datos y los informes.

Syntax

db.collection.aggregate(pipeline, options)
  • canalización: matriz de fases de agregación que procesan y transforman los datos.
  • opciones: opcional. Especifica más opciones para la agregación, como explain, allowDiskUsey cursor.

Examples

Ejemplo 1: Cálculo de ventas totales por categoría

En este ejemplo se muestra cómo calcular las ventas totales de cada categoría de la stores colección.

db.stores.aggregate([
  {
    $unwind: "$sales.salesByCategory"
  },
  {
    $group: {
      _id: "$sales.salesByCategory.categoryName",
      totalSales: { $sum: "$sales.salesByCategory.totalSales" }
    }
  }
])

Salida de ejemplo

[
  { "_id": "Christmas Trees", "totalSales": 3147281 },
  { "_id": "Nuts", "totalSales": 3002332 },
  { "_id": "Camping Tables", "totalSales": 4431667 }
]

Ejemplo 2: Buscar tiendas con personal a tiempo completo superior a 10

En este ejemplo se muestra cómo filtrar los almacenes en los que el número de personal a tiempo completo es mayor que 10.

db.stores.aggregate([
  {
    $match: {
      "staff.totalStaff.fullTime": { $gt: 10 }
    }
  }
])

Salida de ejemplo

[
  {
    "_id": "7954bd5c-9ac2-4c10-bb7a-2b79bd0963c5",
    "name": "Lenore's DJ Equipment Store",
    "location": { "lat": -9.9399, "lon": -0.334 },
    "staff": { "totalStaff": { "fullTime": 18, "partTime": 7 } },
    "sales": {
      "totalSales": 35911,
      "salesByCategory": [ { "categoryName": "DJ Headphones", "totalSales": 35911 } ]
    },
    "promotionEvents": [
      {
        "discounts": [
          { "categoryName": "DJ Turntables", "discountPercentage": 18 },
          { "categoryName": "DJ Mixers", "discountPercentage": 15 }
        ]
      }
    ],
    "tag": [ "#SeasonalSale", "#FreeShipping", "#MembershipDeals" ]
  }
]

Ejemplo 3: Enumerar todos los eventos de promoción con descuentos superiores a 15%

En este ejemplo se enumeran todos los eventos de promoción en los que cualquier descuento es mayor que 15%.

db.stores.aggregate([
  {
    $unwind: "$promotionEvents"
  },
  {
    $unwind: "$promotionEvents.discounts"
  },
  {
    $match: {
      "promotionEvents.discounts.discountPercentage": { $gt: 15 }
    }
  },
  {
    $group: {
      _id: "$promotionEvents.eventName",
      discounts: { $push: "$promotionEvents.discounts" }
    }
  }
])

Salida de ejemplo

[
  {
    "discounts": [
      { "categoryName": "Basketball Gear", "discountPercentage": 23 },
      { "categoryName": "Wool Carpets", "discountPercentage": 22 },
      {
        "categoryName": "Portable Bluetooth Speakers",
        "discountPercentage": 24
      }
    ]
  }
]