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

0

173
Views
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

almost 3 years ago · Santiago Trujillo
1 answers
Answer question

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