MongoDB
 sql >> Database >  >> NoSQL >> MongoDB

Come posso calcolare il prezzo positivo e negativo usando mongodb o robomongo?

Puoi farlo usando conditional sum ed esporta in un'altra raccolta usa $out: collectionName

puoi provarlo :

db.getCollection('userpricing').aggregate([
    {$group: {
        _id:"$user_id", 
        user_id: {$first: "$user_id"}, 
        Totalpositiveprice:{$sum:{$cond:[{ '$gt': ['$price', 0]}, "$price", 0]}}, 
        Totalnegativeprice:{$sum:{$cond:[{ '$lt': ['$price', 0]}, "$price", 0]}},
        Balanceprice:{"$sum":"$price"}}
     },
     {$project: {_id:0, user_id:1, Totalpositiveprice:1, Totalnegativeprice:1, Balanceprice:1}},
     {$out: "summary"}
])

NB: risultato esportato nel riepilogo raccolta