sql >> Databasteknik >  >> NoSQL >> MongoDB

mongodb flera aggregationer i en operation

Börjar i Mongo 3.4 , $facet aggregeringsstadiet förenklar denna typ av användningsfall avsevärt genom att bearbeta flera aggregeringspipelines inom ett enda steg på samma uppsättning indatadokument:

// { "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. MongoDB uppdaterar inte data automatiskt?

  2. spring-data-mongo - valfria frågeparametrar?

  3. Unikt index i mongoDB 3.2 ignorerar nollvärden

  4. Integrationstestning med Testcontainers + Quarkus + MongoDB