• Jobs
  • About Us
  • professionals
    • Home
    • Jobs
    • Courses and challenges
  • business
    • Home
    • Post vacancy
    • Our process
    • Pricing
    • Assessments
    • Payroll
    • Blog
    • Sales
    • Salary Calculator

0

186
Views
Consulta de resultados de grupos agregados de MongoDB por campos comunes

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!!

about 3 years ago · Santiago Trujillo
1 answers
Answer question

0

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" } } } ])

Parque infantil Mongo

about 3 years ago · Santiago Trujillo Report
Answer question
Find remote jobs

Discover the new way to find a job!

Top jobs
Top job categories
Business
Post vacancy Pricing Our process Sales
Legal
Terms and conditions Privacy policy
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recommend me some offers
I have an error