Hinweis
Für den Zugriff auf diese Seite ist eine Autorisierung erforderlich. Sie können versuchen, sich anzumelden oder das Verzeichnis zu wechseln.
Für den Zugriff auf diese Seite ist eine Autorisierung erforderlich. Sie können versuchen, das Verzeichnis zu wechseln.
Der $zip Operator wird verwendet, um zwei oder mehr Arrays elementweise in einem einzigen Array von Arrays zusammenzuführen. Es ist nützlich, wenn Sie verwandte Elemente aus mehreren Arrays in einer einzigen Arraystruktur kombinieren möchten.
Syntax
{
$zip: {
inputs: [ <array1>, <array2>, ... ],
useLongestLength: <boolean>, // Optional
defaults: <array> // Optional
}
}
Die Parameter
| Parameter | Description |
|---|---|
inputs |
Ein Array von Arrays, die elementweise zusammengeführt werden sollen. |
useLongestLength |
Ein boolescher Wert, der bei Festlegung auf "true" die längste Länge der Eingabearrays verwendet. Wenn "false" angegeben oder nicht angegeben wird, wird die kürzeste Länge verwendet. |
defaults |
Ein Array von Standardwerten, die verwendet werden sollen, wenn useLongestLength wahr ist und ein Eingabearray kürzer als das längste Array ist. |
Examples
Betrachten Sie dieses Beispieldokument aus der Stores-Sammlung.
{
"_id": "0fcc0bf0-ed18-4ab8-b558-9848e18058f4",
"name": "First Up Consultants | Beverage Shop - Satterfieldmouth",
"location": {
"lat": -89.2384,
"lon": -46.4012
},
"staff": {
"totalStaff": {
"fullTime": 8,
"partTime": 20
}
},
"sales": {
"totalSales": 75670,
"salesByCategory": [
{
"categoryName": "Wine Accessories",
"totalSales": 34440
},
{
"categoryName": "Bitters",
"totalSales": 39496
},
{
"categoryName": "Rum",
"totalSales": 1734
}
]
},
"promotionEvents": [
{
"eventName": "Unbeatable Bargain Bash",
"promotionalDates": {
"startDate": {
"Year": 2024,
"Month": 6,
"Day": 23
},
"endDate": {
"Year": 2024,
"Month": 7,
"Day": 2
}
},
"discounts": [
{
"categoryName": "Whiskey",
"discountPercentage": 7
},
{
"categoryName": "Bitters",
"discountPercentage": 15
},
{
"categoryName": "Brandy",
"discountPercentage": 8
},
{
"categoryName": "Sports Drinks",
"discountPercentage": 22
},
{
"categoryName": "Vodka",
"discountPercentage": 19
}
]
},
{
"eventName": "Steal of a Deal Days",
"promotionalDates": {
"startDate": {
"Year": 2024,
"Month": 9,
"Day": 21
},
"endDate": {
"Year": 2024,
"Month": 9,
"Day": 29
}
},
"discounts": [
{
"categoryName": "Organic Wine",
"discountPercentage": 19
},
{
"categoryName": "White Wine",
"discountPercentage": 20
},
{
"categoryName": "Sparkling Wine",
"discountPercentage": 19
},
{
"categoryName": "Whiskey",
"discountPercentage": 17
},
{
"categoryName": "Vodka",
"discountPercentage": 23
}
]
}
]
}
Beispiel 1: Grundlegende Verwendung
Angenommen, Sie möchten die categoryName Felder aus totalSales dem salesByCategory Array zusammenführen. Diese Abfrage gibt einzelne Arrays von Arrays unter categoryWithSales Feld zurück.
useLongestLengthwird so true festgelegt, dass die folgende Ausgabe zurückgegeben wird, während ein Wert des falseNapkins Arrays aus der Ausgabe entfernt wird.
db.stores.aggregate([{
$match: {
_id: "a715ab0f-4c6e-4e9d-a812-f2fab11ce0b6"
}
},
{
$project: {
name: 1,
categoryNames: "$sales.salesByCategory.categoryName",
totalSales: "$sales.salesByCategory.totalSales",
categoryWithSales: {
$zip: {
inputs: ["$sales.salesByCategory.categoryName", "$sales.salesByCategory.totalSales"],
useLongestLength: false
}
}
}
}
])
Diese Abfrage gibt das folgende Ergebnis zurück.
[
{
"_id": "a715ab0f-4c6e-4e9d-a812-f2fab11ce0b6",
"name": "Lakeshore Retail | Holiday Supply Hub - Marvinfort",
"categoryNames": ["Stockings"],
"totalSales": [25731],
"categoryWithSales": [["Stockings", 25731]]
}
]
Verwandte Inhalte
- Überprüfen Sie die Optionen für die Migration von MongoDB zu Azure DocumentDB.
- Weitere Informationen zur Featurekompatibilität mit MongoDB.