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

mongodb více agregací v jedné operaci

Počínaje verzí Mongo 3.4 , $facet agregační fáze značně zjednodušuje tento typ případu použití zpracováním více agregačních kanálů v rámci jedné fáze na stejné sadě vstupních dokumentů:

// { "item" : "i1", "category" : "c1", "brand" : "b1" }
// { "item" : "i2", "category" : "c2", "brand" : "b1" }
// { "item" : "i3", "category" : "c1", "brand" : "b2" }
// { "item" : "i4", "category" : "c2", "brand" : "b1" }
// { "item" : "i5", "category" : "c1", "brand" : "b2" }
db.collection.aggregate(
  { $facet: {
      categories: [{ $group: { _id: "$category", count: { "$sum": 1 } } }],
      brands:     [{ $group: { _id: "$brand",    count: { "$sum": 1 } } }]
  }}
)
// {
//   "categories" : [
//     { "_id" : "c1", "count" : 3 },
//     { "_id" : "c2", "count" : 2 }
//   ],
//   "brands" : [
//     { "_id" : "b1", "count" : 3 },
//     { "_id" : "b2", "count" : 2 }
//   ]
// }


  1. 3 způsoby, jak skrýt index z plánu dotazů v MongoDB

  2. Nelze spustit službu MongoDB 3.0.2 na CentOS 7

  3. Ukládání souborů v MongoDB pomocí GridFS

  4. Šifrování MongoDB Data-at-Rest