sql >> Database >  >> NoSQL >> MongoDB

mongodb meerdere aggregaties in één bewerking

Beginnend in Mongo 3.4 , de $facet aggregatiefase vereenvoudigt dit type gebruiksscenario aanzienlijk door meerdere aggregatiepijplijnen binnen één enkele fase op dezelfde set invoerdocumenten te verwerken:

// { "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. $locationProvider html5mode veroorzaakt kan geen fout KRIJGEN bij verversen - AngularJS Node-app

  2. rangschikkingsbord in mongo met omringende spelers

  3. hoe lees je alle bytes die op een tcp-verbinding komen?

  4. Is er een manier om python-objecten rechtstreeks in mongoDB op te slaan zonder ze te serialiseren?