MongoDB
 sql >> база данни >  >> NoSQL >> MongoDB

Как мога да изчисля обща положителна, обща отрицателна цена и сума с помощта на Node.js и Mongoose

Като се има предвид, че очакваните резултати са числа и стойностите от summary колекцията са числа (в противен случай трябва да ги направите числа) ето агрегиране, което изчислява резултата:

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

Резултат:

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
}

По-късно трябва да ги конвертирате в низ, ако имате нужда.

Забележка: Резултатът, който замества обобщената колекция с нови изчислени (и актуализирани) стойности. По-добре първо тествайте резултатите си.



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Cassandra срещу MongoDB:кое да изберете

  2. Golang/mgo:Как мога да поискам от MongoDB да използва текущото време в поле?

  3. Как да съхранявате файлове в MongoDB?

  4. MongoDb близо/geonear заявка с променливо разстояние

  5. Как да конфигурирам MongoDB клъстер, който поддържа сесии?