• Empleos
  • Sobre nosotros
  • profesionales
    • Inicio
    • Empleos
    • Cursos y retos
  • empresas
    • Inicio
    • Publicar vacante
    • Nuestro proceso
    • Precios
    • Evaluaciones
    • Nómina
    • Blog
    • Comercial
    • Calculadora de salario

0

182
Vistas
expresa la suma de agregación de mongoDB

Tengo muchos registros en mi colección mongodb y necesito contar alguna información.

formato de registros:

 { "_id" : someId, "targetFrom" : ObjectId("603e0355e805140334e79438"),<-- this is ID for search "targetTo" : null, "operationPaid" : true, "type" : "coming", <--- type "moneyAccount" : someId, "agent" : null, "sum" : 5000, <--- sum } { "_id" : someId, "targetFrom" : null, "targetTo" : null, "operationPaid" : true, "type" : "out", <--- type "moneyAccount" : someId, "agent" : ObjectId("603e0355e805140334e79438"),<-- this is ID for search "sum" : 3000, <--- sum }

entonces, necesito agrupar por TIPO de registros y obtener SUM para id ObjectId ("603e0355e805140334e79438"), pero la identificación para la búsqueda puede ser el campo targetFrom o targetTo o agent

para este ejemplo necesito obtener el resultado 2000

viene sum 5000 y sale sum 3000 con

over 3 years ago · Santiago Trujillo
1 Respuestas
Responde la pregunta

0

Consulta

  • haga coincidir el Id en uno de los 3 campos posibles
  • grupo por nulo (toda la colección 1 grupo), si type="out" , resto el campo de suma, de lo contrario, agrego al campo de suma

Código de prueba aquí

 aggregate( [{"$match": {"$expr": {"$or": [{"$eq":["$targetFrom", ObjectId("603e0355e805140334e79438")]}, {"$eq":["$targetTo", ObjectId("603e0355e805140334e79438")]}, {"$eq":["$agent", ObjectId("603e0355e805140334e79438")]}]}}}, {"$group": {"_id":null, "sum": {"$sum": {"$cond": [{"$eq":["$type", "out"]}, {"$subtract":[0, "$sum"]}, "$sum"]}}}}])
over 3 years ago · Santiago Trujillo Denunciar
Responde la pregunta
Encuentra empleos remotos

¡Descubre la nueva forma de encontrar empleo!

Top de empleos
Top categorías de empleo
Empresas
Publicar vacante Precios Nuestro proceso Comercial
Legal
Términos y condiciones Política de privacidad
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recomiéndame algunas ofertas
Necesito ayuda