Хобрук: Ваш путь к мастерству в программировании

Несколько условий агрегации Mongo db

Я хочу спроецировать коллекцию, применяя экспорт значения, только если поле находится внутри диапазона.

Вроде, как бы, что-то вроде:

db.workouts.aggregate({
 $match: { user_id: ObjectId(".....") }
},
{
 $project: { 
        '20': { $cond: [ {$gt: [ "$avg_intensity", 20]} , '$total_volume', 0] }
    }    
 })

Мне нужно получить значение, только если avg_intensity находится в определенном диапазоне. Затем я сгруппирую и суммирую результаты прогнозирования.

То, что я пытаюсь сделать, это применить фильтр $ gt и $ lt, но без особого успеха.

db.workouts.aggregate(
{
   $match: { user_id: ObjectId("....") }
},
{
$project: { 
        '20': { $cond: [ [{$gt: [ "$avg_intensity", 20]}, {$lt: [ "$avg_intensity", 25]}] ,    '$total_volume', 0] }
    }    
 })

Как я могу применить оба условия $gt и $lt?


Ответы:


1

Чтобы объединить логические условия в операторе $cond, затем оберните условия с оператором $and:

db.workouts.aggregate([
    { "$match": { "user_id": ObjectId("....") }},
    { "$project": { 
       "20": { "$cond": [
           { "$and": [ 
               { "$gt": [ "$avg_intensity", 20 ] },
               { "$lt": [ "$avg_intensity", 25 ] }
           ]},    
           "$total_volume", 
           0
       ]}
   }}
])
26.04.2014

2

Если я правильно понял ваши требования, вы должны поместить фильтр в соответствующую часть конвейера:

db.workouts.aggregate( [
  { $match: { user_id: ObjectId("...."), "avg_intensity": { $gt: 20, $lte: 25 } } },
  { $group: { _id: ..., count: ... } }
] );
23.04.2014
  • Это решение, но я бы закончил делать больше запросов. Я забыл упомянуть, что мне нужно сделать больше подмножеств. Es: возьмите любой результат от 20 до 40, затем возьмите результаты от 40 до 60 и т. д.... Поэтому я хотел бы сгруппировать их, потому что у меня может быть больше подмножеств в результате выполнения одной и той же агрегации. 24.04.2014

  • 3

    Мы можем агрегировать следующим образом. Здесь я использую два условия: город, год.

    db.getCollection('geolocations').aggregate(
       [{$unwind : '$geolocation'},
         {
           $group:
             {
               _id: {city:"$geolocation.city",year: { $year: "$geolocation.date" }},
               count: { $sum: 1 }
             }
         }
       ]
    )
    

    Выход:

    /* 1 */
    {
        "_id" : {
            "city" : "Noida",
            "year" : 2020
        },
        "count" : 1.0
    }
    
    /* 2 */
    {
        "_id" : {
            "city" : "Villupuram",
            "year" : 2020
        },
        "count" : 1.0
    }
    
    /* 3 */
    {
        "_id" : {
            "city" : "Chennai",
            "year" : 2020
        },
        "count" : 2.0
    }
    
    08.02.2020
    Новые материалы

    ВЫ РЕГРЕСС ЭТО?
    Чтобы понять, когда использовать регрессионный анализ, мы должны сначала понять, что именно он делает. Вот простой ответ, который появляется, когда вы используете Google: Регрессионный..

    Не зря же это называют интеллектом
    Стек — C#, Oracle Опыт — 4 года Работа — Разведывательный корпус Мне пора служить Может быть, я немного приукрашиваю себя, но там, где я живу, есть обязательная военная служба на 3..

    LeetCode Проблема 41. Первый пропущенный положительный результат
    LeetCode Проблема 41. Первый пропущенный положительный результат Учитывая несортированный массив целых чисел, найдите наименьшее пропущенное положительное целое число. Пример 1: Input:..

    Расистский и сексистский робот, обученный в Интернете
    Его ИИ основан на предвзятых данных, которые создают предрассудки. Он словно переходит из одного эпизода в другой из серии Черное зеркало , а вместо этого представляет собой хронику..

    Управление состоянием в микрофронтендах
    Стратегии бесперебойного сотрудничества Микро-фронтенды — это быстро растущая тенденция в сфере фронтенда, гарантирующая, что удовольствие не ограничивается исключительно бэкэнд-системами..

    Декларативное и функциональное программирование в стиле LINQ с использованием JavaScript с использованием каррирования и генератора ...
    LINQ - одна из лучших функций C #, которая обеспечивает элегантный способ написания кода декларативного и функционального стиля, который легко читать и понимать. Благодаря таким функциям ES6,..

    Структуры данных в C ++ - Часть 1
    Реализация общих структур данных в C ++ C ++ - это расширение языка программирования C, которое поддерживает создание классов, поэтому оно известно как C с классами . Он используется для..