Not
Bu sayfaya erişim yetkilendirme gerektiriyor. Oturum açmayı veya dizinleri değiştirmeyi deneyebilirsiniz.
Bu sayfaya erişim yetkilendirme gerektiriyor. Dizinleri değiştirmeyi deneyebilirsiniz.
işleci $mergeObjects birden çok belgeyi tek bir belgede birleştirir. mergeObjects işlemi, farklı belgelerdeki alanları birleştirmek veya var olan bir belgeye bir veya daha fazla alan eklemek için toplama işlem hatlarında kullanılır. İşleç, çakışmalar oluştuğunda kaynak belgedeki alanlarla hedef belgedeki alanların üzerine yazar.
Sözdizimi
{
$mergeObjects: [ < document1 > , < document2 > , ...]
}
Parametreler
| Parametre | Description |
|---|---|
document1, document2 |
Birleştirilecek belgeler. Belgeler alan yolları, alt belgeler veya sabitler olarak belirtilebilir. |
Örnekler
Stores koleksiyonundaki bu örnek belgeyi göz önünde bulundurun.
{
"_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
}
]
}
]
}
Örnek 1 - Belgeleri satış alt belgesine göre gruplandırmak için belgeleri bir biriktirici olarak birleştirme
Sorgu, belirli bir şirket için şehir başına tüm satış alt belgeleri birleştirir.
db.stores.aggregate([
{
$match: {
company: "Fourth Coffee"
}
},
{
$group: {
_id: "$city",
mergedSales: {
$mergeObjects: "$sales"
}
}
},
{
$limit: 2 // returns only the first 3 grouped cities
}
])
Bu sorgu tarafından döndürülen ilk iki sonuç şunlardır:
[
{
"_id": "Jalonborough",
"mergedSales": {
"totalSales": 45747,
"salesByCategory": [
{
"categoryName": "Bucket Bags",
"totalSales": 45747
}
]
}
},
{
"_id": "Port Vladimir",
"mergedSales": {
"totalSales": 32000,
"salesByCategory": [
{
"categoryName": "DJ Speakers",
"totalSales": 24989
},
{
"categoryName": "DJ Cables",
"totalSales": 7011
}
]
}
}
]
İlgili içerik
- MongoDB'den Azure DocumentDB'ye geçiş seçeneklerini gözden geçirin.
- MongoDB ile özellik uyumluluğu hakkında daha fazla bilgi edinin.