Всем привет! Ребята, есть такая задача. В коллекции users есть

документы такого рода:
{
"_id" : ObjectId("5d78edf6c58fa231cca1eec6"),
"visitCount" : 2,
"purchases" : [
{
"title" : "smartphone Samsung",
"price" : 120,
"bought" : ISODate("2019-09-13T09:44:00Z")
},
{
"title" : "smartphone iPhone",
"price" : 200,
"bought" : ISODate("2019-09-08T09:44:00Z")
}
],
"views" : [
{
"page" : "index.html",
"time" : ISODate("2019-09-13T09:44:00Z")
},
{
"page" : "smarthpones.html",
"time" : ISODate("2019-09-09T09:44:00Z")
},
{
"page" : "about.html",
"time" : ISODate("2019-09-08T09:44:00Z")
}
]
}
И с помощью Aggregation pipeline нужно выбрать таких (хотя бы их айдишники), которые удовлетворяют следующему условию: (СРЕДНЯЯ сумма покупок price из коллекции purchase в диапазоне между 9 и 14 сентября не больше 120 руб) И (
(Количество просмотров из коллекции views в диапазоне дат между 9 и 14 сентября не больше 3). Я хочу подсчитать эти показатели изначально с помощью стадии $addFields. Основная сложность возникла, связанная с поиском средней суммы покупок purchase за определенный диапазон.
Если обычную сумму покупок за опр. диапазон посчитать получилось:
$addFields: {
purchaseSum: {
$reduce: {
input: "$purchases",
initialValue: 0,
in: {
$add : [
"$$value",
{ $cond: {
if: { $gte: [ "$$this.bought", ISODate('2019-09-11')] },
then: "$$this.price",
else: 0
}}
]
}
}
}
}
},
Вопрос: Как вместо purchaseSum вычислить СРЕДНЕЕ арифметическое за диапазон в данном случае?

1 ответов

15 просмотров

первым шагом посчитать сумму и количество суммируемых элементов, а вторым поделить сумму на количество

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

Обсуждают сегодня

Ребята, всем привет. Подскажите, пожалуйста, можно ли как-то через бота понять, что этого бота добавили в группу\канал и выдали ему права администратора?
Artem Stormageddon
9
Это переведённый текст с английского. Я не говорю на русском, но могу использовать переводчик Телеграм. Приветствую! Я начинающий веб-разработчик и все еще учусь. В настояще...
𐩱𐩪𐩣𐩱𐩲𐩺𐩡
3
А не хотим ли мы развлечься? 😉 Но так чтобы с пользой для наших профессиональных навыков?? 👨‍🎓👩‍🎓 Предлагаю на октябрь запланировать тестовый запуск новой командной игры "Игр...
Andrii Kurdiumov
2
Привет всем! Почему этот код не срабатывает при добавлении или удалении пользователя из чата? bot.on('chat_member', async (ctx) => { console.log(ctx); }) bot.launch({allo...
Alexander
5
у кого сколько оперативы на базе данных ?
АДИЛЬБЕК
4
Через бот апи возможно получить ID стикерпака? Не ссылку.
Vexylon [АФК до 09.09]
5
Привет Хочу сделать аналог iCloud’а для своих проектов, чтобы пользовательская информация хранилась в облаке, была доступна во всех сервисах, её можно было подсасывать везде)...
Виталий
9
В тг можно спарсить всех кто пишет в группе? Если список участников скрыт
S
3
код Event::listen('cms.page.display', function (&$content, $slug, $page, $html) { if (is_object($content)) { dump($content); } else { dump($s...
Point 111
3
Всем привет. Не понимаю, в чём тут шутка юмора. Убирается только разрешение на send_messages. А send_media_messages остаётся. Как сделать, чтобы оба убирались? await b...
Alexander
2
Карта сайта