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 $arrayToObject operator wordt gebruikt om een matrix te converteren naar één document. Deze operator is handig wanneer u matrices van sleutel-waardeparen moet transformeren in een meer gestructureerde documentindeling.
Syntaxis
{
$arrayToObject: "<array>"
}
Parameterwaarden
| Kenmerk | Description |
|---|---|
<array> |
De matrix die moet worden geconverteerd naar een document. Elk element in de matrix moet een van de volgende zijn: a) Een matrix met twee elementen waarbij het eerste element de veldnaam is en het tweede element de veldwaarde is. b) Een document met precies twee velden, 'k' en 'v', waarbij 'k' de veldnaam is en 'v' de veldwaarde is. |
Voorbeelden
Bekijk dit voorbeelddocument uit de winkelverzameling.
{
"_id": "7954bd5c-9ac2-4c10-bb7a-2b79bd0963c5",
"name": "Lakeshore Retail | DJ Equipment Stop - Port Cecile",
"location": {
"lat": 60.1441,
"lon": -141.5012
},
"staff": {
"totalStaff": {
"fullTime": 2,
"partTime": 0
}
},
"sales": {
"salesByCategory": [
{
"categoryName": "DJ Headphones",
"totalSales": 35921
},
{
"categoryName": "DJ Cables",
"totalSales": 1000
}
],
"fullSales": 3700
},
"promotionEvents": [
{
"eventName": "Bargain Blitz Days",
"promotionalDates": {
"startDate": {
"Year": 2024,
"Month": 3,
"Day": 11
},
"endDate": {
"Year": 2024,
"Month": 2,
"Day": 18
}
},
"discounts": [
{
"categoryName": "DJ Turntables",
"discountPercentage": 18
},
{
"categoryName": "DJ Mixers",
"discountPercentage": 15
}
]
},
{
"eventName": "Discount Delight Days",
"promotionalDates": {
"startDate": {
"Year": 2024,
"Month": 5,
"Day": 11
},
"endDate": {
"Year": 2024,
"Month": 5,
"Day": 18
}
}
}
],
"tag": [
"#ShopLocal",
"#FashionStore",
"#SeasonalSale",
"#FreeShipping",
"#MembershipDeals"
]
}
Voorbeeld 1: De matrix converteren naar een sleutel: waardedocument
Met deze query wordt de salesByCategory matrix geconverteerd naar een object waarbij elk categoryName een sleutel is en totalSales de bijbehorende waarde is. Deze transformatie vereenvoudigt de toegang tot verkoopgegevens per categorie rechtstreeks vanuit een objectstructuur.
db.stores.aggregate([{
$match: {
_id: "7954bd5c-9ac2-4c10-bb7a-2b79bd0963c5"
}
},
{
$project: {
"sales.salesByCategory": {
$arrayToObject: {
$map: {
input: "$sales.salesByCategory",
as: "item",
in: {
k: "$$item.categoryName",
v: "$$item.totalSales"
}
}
}
}
}
}
])
De query retourneert het volgende resultaat.
[
{
"_id": "7954bd5c-9ac2-4c10-bb7a-2b79bd0963c5",
"sales": {
"salesByCategory": {
"DJ Headphones": 35921,
"DJ Cables": 1000
}
}
}
]
Verwante inhoud
- Bekijk de opties voor het migreren van MongoDB naar Azure DocumentDB.
- Lees meer over functiecompatibiliteit met MongoDB.