.select () из Mongoose doc и count subdocs [duplicate]

16
задан randombits 27 January 2014 в 19:49
поделиться

3 ответа

Вы можете попробовать подсчитать предметы в еде.

 db.collection.aggregate([{$project: {numberOfFoos: { $size: "$foos" } } } ] )
-3
ответ дан jitendra rajput 26 August 2018 в 05:40
поделиться

В MongoDB 2.6 у Aggregation Framework есть новый массив $size , который вы можете использовать:

> db.mycollection.insert({'foo':[1,2,3,4]})
> db.mycollection.insert({'foo':[5,6,7]})

> db.mycollection.aggregate({$project: { count: { $size:"$foo" }}})
{ "_id" : ObjectId("5314b5c360477752b449eedf"), "count" : 4 }
{ "_id" : ObjectId("5314b5c860477752b449eee0"), "count" : 3 }
34
ответ дан Stennie 26 August 2018 в 05:40
поделиться

, если вы находитесь в последней версии mongo (2.2 и более поздней), вы можете использовать структуру агрегации.

db.mycollection.aggregate([
  {$unwind: '$foo'},
  {$group: {_id: '$_id', 'sum': { $sum: 1}}},
  {$group: {_id: null, total_sum: {'$sum': '$sum'}}}
])

, которая даст вам общую foo s вашей коллекции.

Опускание последнего group будет агрегировать результаты на запись.

16
ответ дан xlembouras 26 August 2018 в 05:40
поделиться
Другие вопросы по тегам:

Похожие вопросы: