Definición
Combina múltiples documentos en un único documento.
$mergeObjects está disponible en estas etapas:
Sintaxis
Cuando se utiliza como acumulador $bucket de etapa, u, $bucketAuto tiene $group $mergeObjects esta sintaxis:
{ $mergeObjects: <document> }
Cuando se utiliza en otras expresiones (incluidas $bucket $bucketAutolas $group etapas, y) pero no como acumulador, $mergeObjects tiene esta sintaxis:
{ $mergeObjects: [ <document1>, <document2>, ... ] }
<document> puede ser cualquier expresión válida que se resuelva en un documento.
Comportamiento
$mergeObjectsignora los operandos null. Si todos los operandos hasta$mergeObjectsse resuelven como nulos, $mergeObjectsdevuelve un documento vacío { }.
$mergeObjects Sobrescribe los valores de los campos al fusionar los documentos. Si los documentos a fusionar incluyen el mismo nombre de campo, este, en el documento resultante, tendrá el valor del último documento fusionado.
Ejemplo | Resultados | ||||||||
|---|---|---|---|---|---|---|---|---|---|
| | ||||||||
| | ||||||||
| | ||||||||
| |
Ejemplos
$mergeObjects
Cree una colección orders con los siguientes documentos:
db.orders.insertMany( [ { "_id" : 1, "item" : "abc", "price" : 12, "ordered" : 2 }, { "_id" : 2, "item" : "jkl", "price" : 20, "ordered" : 1 } ] )
Crea otra colección items con los siguientes documentos:
db.items.insertMany( [ { "_id" : 1, "item" : "abc", description: "product 1", "instock" : 120 }, { "_id" : 2, "item" : "def", description: "product 2", "instock" : 80 }, { "_id" : 3, "item" : "jkl", description: "product 3", "instock" : 60 } ] )
La siguiente operación utiliza primero la etapa para unir las dos colecciones mediante $lookup los item campos y luego utiliza $mergeObjects en para fusionar los documentos $replaceRoot unidos items de orders y:
db.orders.aggregate( [ { $lookup: { from: "items", localField: "item", // field in the orders collection foreignField: "item", // field in the items collection as: "fromItems" } }, { $replaceRoot: { newRoot: { $mergeObjects: [ { $arrayElemAt: [ "$fromItems", 0 ] }, "$$ROOT" ] } } }, { $project: { fromItems: 0 } } ] )
La operación devuelve los siguientes documentos:
{ _id: 1, item: 'abc', description: 'product 1', instock: 120, price: 12, ordered: 2 }, { _id: 2, item: 'jkl', description: 'product 3', instock: 60, price: 20, ordered: 1 }
$mergeObjects como acumulador
Cree una colección sales con los siguientes documentos:
db.sales.insertMany( [ { _id: 1, year: 2017, item: "A", quantity: { "2017Q1": 500, "2017Q2": 500 } }, { _id: 2, year: 2016, item: "A", quantity: { "2016Q1": 400, "2016Q2": 300, "2016Q3": 0, "2016Q4": 0 } } , { _id: 3, year: 2017, item: "B", quantity: { "2017Q1": 300 } }, { _id: 4, year: 2016, item: "B", quantity: { "2016Q3": 100, "2016Q4": 250 } } ] )
La siguiente operación utiliza como acumulador $mergeObjects $group en una etapa que agrupa documentos item por el campo:
Nota
Cuando se utiliza como un acumulador, el operador $mergeObjects acepta un único operando.
db.sales.aggregate( [ { $group: { _id: "$item", mergedSales: { $mergeObjects: "$quantity" } } } ] )
La operación devuelve los siguientes documentos:
{ _id: 'A', mergedSales: { '2017Q1': 500, '2017Q2': 500, '2016Q1': 400, '2016Q2': 300, '2016Q3': 0, '2016Q4': 0 } }, { _id: 'B', mergedSales: { '2017Q1': 300, '2016Q3': 100, '2016Q4': 250 } }
Nota
Si los documentos a fusionar incluyen el mismo nombre de campo, el campo en el documento resultante tendrá el valor del último documento fusionado para el campo.