Megosztás a következőn keresztül:


$unwind (összesítés)

Az aggregációs keretrendszer $unwind szakasza a tömbmezőknek a bemeneti dokumentumokból való dekonstruálására szolgál, hogy minden elemhez kiírjon egy dokumentumot. Minden kimeneti dokumentum az eredeti példány másolata, de a tömbmező értékét egyetlen elem váltja fel. Ez különösen hasznos a tömbökben tárolt adatok normalizálásához és a tömb egyes elemein végzett műveletek külön-külön történő végrehajtásához.

Szemantika

{
  $unwind: {
    path: <field path>,
    includeArrayIndex: <string>, // Optional
    preserveNullAndEmptyArrays: <boolean> // Optional
  }
}

Paraméterek

Leírás
path Egy tömbmező mezőútvonala. Ez egy kötelező paraméter.
includeArrayIndex Opcionális. A megkerülő elem tömbindexének tárolására használt új mező neve.
preserveNullAndEmptyArrays Opcionális. Ha igaz, ha az elérési út null, hiányzik vagy üres tömb, $unwind a dokumentumot változatlanul adja ki.

Példa(ák)

1. példa: Értékesítések visszatekerése kategória szerint

A salesByCategory tömb dekonstruálásához a tárdokumentumban:

db.stores.aggregate([
  {
    $unwind: "$store.sales.salesByCategory"
  }
])

Példakimenet

[
  {
    "_id": "7954bd5c-9ac2-4c10-bb7a-2b79bd0963c5",
    "store": {
      "name": "Downtown Store",
      "sales": {
        "totalSales": 15000,
        "salesByCategory": {
          "category": "Electronics",
          "totalSales": 5000
        }
      }
    }
  },
  {
    "_id": "7954bd5c-9ac2-4c10-bb7a-2b79bd0963c5",
    "store": {
      "name": "Downtown Store",
      "sales": {
        "totalSales": 15000,
        "salesByCategory": {
          "category": "Clothing",
          "totalSales": 10000
        }
      }
    }
  }
]

Ez olyan dokumentumokat ad ki, ahol minden dokumentum egyetlen kategória értékesítési adatait jeleníti meg.

2. példa: Előléptetési események visszatekerése tömbindexkel

A promotionEvents tömb dekonstruálásához és a tömbindex kimenetbe való belefoglalásához:

db.stores.aggregate([
  {
    $unwind: {
      path: "$store.promotionEvents",
      includeArrayIndex: "eventIndex"
    }
  }
])

Példakimenet

[
  {
    "_id": "7954bd5c-9ac2-4c10-bb7a-2b79bd0963c5",
    "store": {
      "name": "Downtown Store",
      "promotionEvents": {
        "eventName": "Summer Sale",
        "eventDate": ISODate("2024-08-01T00:00:00Z")
      },
      "eventIndex": 0
    }
  },
  {
    "_id": "7954bd5c-9ac2-4c10-bb7a-2b79bd0963c5",
    "store": {
      "name": "Downtown Store",
      "promotionEvents": {
        "eventName": "Black Friday",
        "eventDate": ISODate("2024-11-25T00:00:00Z")
      },
      "eventIndex": 1
    }
  }
]

Ez olyan dokumentumokat ad ki, amelyekben minden dokumentum egyetlen előléptetési eseményt jelöl, az EventIndex mező pedig az esemény eredeti indexét tartalmazza a tömbben.

3. példa: Kedvezmények visszatekerése a promóciós eseményeken belül

A kedvezmények tömbjének bontása az egyes promóciós eseményeken belül, és a dokumentumok megőrzése kedvezmények nélkül:

db.stores.aggregate([
  {
    $unwind: {
      path: "$store.promotionEvents.discounts",
      preserveNullAndEmptyArrays: true
    }
  }
])

Példakimenet

[
  {
    "_id": "7954bd5c-9ac2-4c10-bb7a-2b79bd0963c5",
    "store": {
      "name": "Downtown Store",
      "promotionEvents": {
        "eventName": "Summer Sale",
        "discounts": {
          "discountType": "Percentage",
          "discountAmount": 20
        }
      }
    }
  },
  {
    "_id": "7954bd5c-9ac2-4c10-bb7a-2b79bd0963c5",
    "store": {
      "name": "Downtown Store",
      "promotionEvents": {
        "eventName": "Black Friday"
      }
    }
  }
]

Ez olyan dokumentumokat ad ki, amelyekben minden dokumentum egyetlen kedvezményt jelöl egy promóciós eseményen belül, és a kedvezmények nélküli dokumentumok megmaradnak.

  • Az Azure Cosmos DB for MongoDB (vCore) rendszerre történő áttelepítés lehetőségeinek áttekintése MongoDB-ből.
  • Első lépésként hozzon létre egy fiókot.