Вы можете попробовать подсчитать предметы в еде.
db.collection.aggregate([{$project: {numberOfFoos: { $size: "$foos" } } } ] )
В 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 }
, если вы находитесь в последней версии mongo (2.2 и более поздней), вы можете использовать структуру агрегации.
db.mycollection.aggregate([
{$unwind: '$foo'},
{$group: {_id: '$_id', 'sum': { $sum: 1}}},
{$group: {_id: null, total_sum: {'$sum': '$sum'}}}
])
, которая даст вам общую foo
s вашей коллекции.
Опускание последнего group
будет агрегировать результаты на запись.