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

Hvordan kan jeg beregne den samlede positive, samlede negative pris og sum ved hjælp af Node.js og Mongoose

I betragtning af, at forventede resultater er tal og værdierne fra summary samling er tal (ellers skal du lave dem til tal) her er en aggregering, der beregner resultatet:

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"}}
     },
    {
      $lookup:
        {
          from: "summary",
          localField: "user_id",
          foreignField: "user_id",
          as: "user_id2"
        }
   },
   {$project: {
    _id:0, 
    user_id:1, 
    Totalpositiveprice: {$sum: ["$Totalpositiveprice", {$sum: "$user_id2.Totalpositiveprice"}] },
    Totalnegativeprice: {$sum: ["$Totalnegativeprice", {$sum: "$user_id2.Totalnegativeprice"}] },
    Balanceprice: {$sum: ["$Balanceprice", {$sum: "$user_id2.Balanceprice"}] },
}},

     {$out: "summary"}
]).pretty()

Resultat:

db.summary.find().pretty()

{
    "_id" : ObjectId("584fde2906c7385883be0d15"),
    "user_id" : 2,
    "Totalpositiveprice" : 10000,
    "Totalnegativeprice" : 0,
    "Balanceprice" : 10000
}
{
    "_id" : ObjectId("584fde2906c7385883be0d16"),
    "user_id" : 1,
    "Totalpositiveprice" : 23000,
    "Totalnegativeprice" : -10000,
    "Balanceprice" : 13000
}

Senere skal du konvertere dem til streng, hvis du har brug for det.

Bemærk: Resultatet tilsidesætter oversigtssamlingen med nye beregnede (og opdaterede) værdier. Test hellere dine resultater først.



  1. Azure DataBricks Stream foreach fejler med NotSerializableException

  2. Sådan opretter du en Redis-forbindelse med Master og Slave

  3. Opret et tekstindeks med forskellige feltvægte i MongoDB

  4. Apache HBase-regionopdeling og sammenlægning