sql >> Databasteknik >  >> NoSQL >> MongoDB

Aggregera med $summa i mongodb

Använd $addToSet ackumulator och sedan $size operatör för att räkna antalet unika projectId

Worksheet.aggregate([
  { $match: conditions },
  { "$group": {
    "_id": null,
    "billingHours": {
      "$sum": {
        "$cond": [{ "$eq": ["$isBilling", true] }, "$hours", 0]
      }
    },
    "fixContract": {
      "$sum": {
        "$cond": [{ "$eq": ["$isBilling", true] }, 0, "$hours"]
      }
    },
    "projectIds": { "$addToSet": "$projectId" }
  }},
  { "$addFields": { "projectIds": { "$size": "$projectIds" }}}
])



  1. Importera en mycket stor postuppsättning till MongoDB med hjälp av nodejs

  2. Hur konverterar man en befintlig relationsdatabas till ett nyckel-värdelager?

  3. Hur kommer man runt detta MongoDB/Node asynkrona problem?

  4. Tillfälligt fel i namnupplösning redis