Notitie
Voor toegang tot deze pagina is autorisatie vereist. U kunt proberen u aan te melden of de directory te wijzigen.
Voor toegang tot deze pagina is autorisatie vereist. U kunt proberen de mappen te wijzigen.
De $zip operator wordt gebruikt om twee of meer matrices elementgewijs samen te voegen in één matrix met matrices. Het is handig als u gerelateerde elementen van meerdere matrices wilt combineren tot één matrixstructuur.
Syntaxis
{
$zip: {
inputs: [ <array1>, <array2>, ... ],
useLongestLength: <boolean>, // Optional
defaults: <array> // Optional
}
}
Parameterwaarden
| Kenmerk | Description |
|---|---|
inputs |
Een matrix met matrices die moeten worden samengevoegd met elementen. |
useLongestLength |
Een Booleaanse waarde die, indien ingesteld op true, de langste lengte van de invoermatrices gebruikt. Als onwaar of niet is opgegeven, wordt de kortste lengte gebruikt. |
defaults |
Een matrix met standaardwaarden die moeten worden gebruikt als useLongestLength waar is en een invoermatrix korter is dan de langste matrix. |
Voorbeelden
Bekijk dit voorbeelddocument uit de winkelverzameling.
{
"_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
}
]
}
]
}
Voorbeeld 1: Basisgebruik
Stel dat u de categoryName velden en totalSales velden uit de salesByCategory matrix wilt samenvoegen. Deze query retourneert afzonderlijke matrices onder categoryWithSales het veld.
useLongestLength ingesteld om true de volgende uitvoer te retourneren, terwijl een waarde van false de Napkins matrix uit de uitvoer wordt verwijderd.
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
}
}
}
}
])
Deze query retourneert het volgende resultaat.
[
{
"_id": "a715ab0f-4c6e-4e9d-a812-f2fab11ce0b6",
"name": "Lakeshore Retail | Holiday Supply Hub - Marvinfort",
"categoryNames": ["Stockings"],
"totalSales": [25731],
"categoryWithSales": [["Stockings", 25731]]
}
]
Verwante inhoud
- Bekijk de opties voor het migreren van MongoDB naar Azure DocumentDB.
- Lees meer over functiecompatibiliteit met MongoDB.