MongoDB
 sql >> Baza danych >  >> NoSQL >> MongoDB

Agreguj z $sumą w mongodb

Użyj $addToSet akumulator, a następnie $size operator do zliczania unikalnych 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. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. 5 sposobów na uzyskanie miesiąca z daty w MongoDB

  2. Aktualizacja tablicy w MongoDB za pomocą sterownika Java

  3. Mongoose zmień nazwę kolekcji

  4. Opcje wyszukiwania pełnotekstowego dla konfiguracji MongoDB

  5. Kompresowanie ciągu szesnastkowego w Ruby/Rails