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
Consulta
type="out"
, resto el campo de suma, de lo contrario, agrego al campo de suma 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"]}}}}])