Buscando descubrir cómo realizar una agrupación particular de documentos Mongo a través de una consulta, en lugar de transformar los resultados a través del código después de obtener los datos.
Muestra de datos simulados:
[ { 'id': 1, 'status': 'EMPTY', 'name': 'ALBERT' }, { 'id': 2, 'status': 'EMPTY', 'name': 'ERIC' }, { 'id': 3, 'status': 'EMPTY', 'name': 'ALBERT' }, { 'id': 4, 'status': 'EMPTY', 'name': 'ALBERT' }, { 'id': 5, 'status': 'EMPTY', 'name': 'JESSICA' }, { 'id': 6, 'status': 'EMPTY', 'name': 'ERIC' }, ... ]
Mi consulta agregada:
db.results.aggregate([ { $match: { 'status': 'EMPTY' } }, ??? ])
Me gustaría transformar/ordenar los resultados en un objeto como este:
{ 'ALBERT': [ { 'id': 1, 'status': 'EMPTY', 'name': 'ALBERT' }, { 'id': 3, 'status': 'EMPTY', 'name': 'ALBERT' }, { 'id': 4, 'status': 'EMPTY', 'name': 'ALBERT' }, ], 'ERIC': [ { 'id': 2, 'status': 'EMPTY', 'name': 'ERIC' }, { 'id': 6, 'status': 'EMPTY', 'name': 'ERIC' } ], 'JESSICA': [ { 'id': 5, 'status': 'EMPTY', 'name': 'JESSICA' } ] }
Es un poco difícil revisar la documentación en línea, ya que ni siquiera estoy seguro de cómo se llama este tipo de transformación o qué agregador debería usar en Mongo. ¡Así que cualquier punto en la dirección correcta sería muy apreciado!
¡¡Gracias!!
Prueba este:
db.collection.aggregate([ { $unset: "_id" }, { $group: { _id: "$name", data: { $push: "$$ROOT" } } }, { $project: { data: { k: "$_id", v: "$data" } } }, { $replaceRoot: { newRoot: { $arrayToObject: "$data" } } }, { $group: { _id: null, data: { $push: "$$ROOT" } } }, { $replaceRoot: { newRoot: { $mergeObjects: "$data" } } } ])