sql >> Databáze >  >> NoSQL >> MongoDB

Jak mohu vypočítat celkovou kladnou, celkovou zápornou cenu a součet pomocí Node.js a Mongoose

Vzhledem k tomu, že očekávané výsledky jsou čísla a hodnoty z summary kolekce jsou čísla (jinak z nich musíte udělat čísla) zde je agregace, která vypočítá výsledek:

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()

Výsledek:

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
}

Později je musíte v případě potřeby převést na řetězec.

Poznámka: Výsledek přepíše souhrnnou kolekci novými vypočítanými (a aktualizovanými) hodnotami. Raději nejprve otestujte své výsledky.



  1. Implementace fulltextového vyhledávání MongoDB 2.4 v aplikaci Meteor

  2. Mongoose aktualizace více dokumentů neaktualizuje nic

  3. Celer vytváří pro každý úkol nové spojení

  4. Převeďte dotaz MongoDB do syntaxe Spring MongoDB