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

Agregovat s $sum v mongodb

Použijte $addToSet akumulátor a poté $size operátor, který spočítá počet jedinečných 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. Jak mohu přidat dvousloupcové jedinečné ID do mongodb v aplikaci meteor?

  2. Nápověda MongoDB Query - dotaz na hodnoty libovolného klíče v dílčím objektu

  3. Projekt pole objektů na klíčovou hodnotu

  4. Typované transakce Redis