Всем привет! Ребята, есть такая задача. В коллекции 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 ответов

14 просмотров

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

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

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

Подскажите, а есть vault lite или ченить такое?) А то нужен вольт для похода в вольт, но весит он ~500 мб) как-то многовато для парочки запросов ))
Alexandr Orloff
17
Всем привет, есть небольшая проблема Есть такой скрипт document.addEventListener('DOMContentLoaded', function () { const sliderTabs = document.querySelectorAll('.s...
A da
8
@go1337 @dblackCat Привет. Все ещё дрочусь с fastpanel. Добавил второй домен который должен смотреть в рут того же сайта, но так как это просто домен, а не сайт, я не могу ему...
Ross 🦴
9
До речі, в ево нема можливості чи якого розширення щоб з адмінки з телефона зайти і терміново щось в верстці поправити?
Женя
7
кто-нибудь пользуется тайм-трекерами во время работы? так много разных нагуглил, может есть что-то популярное
Lencore
8
Пацаны. Я разрабатываю софт для инвайтинга на телетон, и столкнулся с такой проблемой, в один из чатов не могу приглашать никого, не дает добавлять, в то же время через официа...
Kernel Panic
11
Скажите, а кому нужен Currency как отдельный плагин вместо полноценного ecommerce в OctoberCMS? Кто-то использует его уже или планирует в будущем? Может я что-то не понимаю?
Igor
13
Розмовами про Рево мені нагадали часи, коли шаблони правилися прямо в адмінці. Хто в курсі, чому відійшли від цієї практики, так блейд не працює? Доволі зручно ж було (інколи)
Женя
3
Всем добрый вечер, Рад оказаться в кругу единомышленников. Начинаю погружаться в мир .net веба. Зовут Ерасыл 🖖 У меня назрел вопрос: Какой процент проектов, прошедшие через в...
Ерасыл
6
Чому? Да тому що без GiT не уявляю нормального проекта а коли код в базі то то так собі
Dmytro Lukianenko
3
Карта сайта