Подтвердить что ты не робот

Запрос суммы MongoDb

Например, у меня есть следующие данные в MongoDB:

{ "_id" : ObjectId("524091f99c49c4c3f66b0e46"), "hour" : 10, "incoming", 100}
{ "_id" : ObjectId("5240a045dbeff33c7333aa51"), "hour" : 11, "incoming", 200}
{ "_id" : ObjectId("5240a2ecda0d37f35c618aca"), "hour" : 12, "incoming", 300}

Теперь я хочу запросить "SUM число входящих между 11 - 12" (результат должен быть 500), как я могу сделать это с помощью Mongo Shell?

4b9b3361

Ответ 1

Как предложил лловец, структура агрегации - это путь. Вот как выглядит ваш запрос:

db.CollectionNameGoesHere.aggregate({ $match: {
    $and: [
        { hour: { $gte: 11 } },
        { hour: { $lte: 12 } }
    ]
} },
{ $group: { _id : null, sum : { $sum: "$incoming" } } });

Вы также можете сформировать результирующий документ только для того, чтобы содержать сумму, добавив оператор $project в конец конвейера, например:

{ $project: { _id: 0, sum: 1 } }

Ответ 2

Некоторые примеры, если вы используете мангуста:

  1. Рассчитать общую сумму цен на продукцию:
Products.aggregate([ { $match: {} }, { $group:
  { _id : null, sum : { $sum: "$Price" } }
}])
.then(res => console.log(res[0].sum));

({ $match: {} }, можно удалить.)


  1. Сумма цен на товары в каждой категории:
Products.aggregate([{ $group:
  { _id : '$Category', sum : { $sum: "$Price" } }
}])
.then(res => console.log(res));