Megjegyzés
Az oldalhoz való hozzáféréshez engedély szükséges. Megpróbálhat bejelentkezni vagy módosítani a címtárat.
Az oldalhoz való hozzáféréshez engedély szükséges. Megpróbálhatja módosítani a címtárat.
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.
Kapcsolódó tartalom
- 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.