kuraga333
@kuraga333
Программист, аналитик

Как отфильтровать массив в каждом элементе массива коллекции MongoDB?

Есть коллекция:

[
  {
    "name": "Alex",
    "cars": [
      {
        "label": "BMW",
        "age": 13,
        "things": [ ... ]
      },
      {
        "label": "Mercedes",
        "age": 8,
        "things": [ ... ]
      }
    ]
  },
  { ... }
]


Надо получить коллекцию без некоторых `thing`'ов, по условию, используя MongoDB aggregations.

Написал код:

db.matches.aggregate([{
  $project: {
    '_id': '$_id',
    'cars': {
      $map: {
        input: '$cars',
        as: 'car',
        in: {
          'things': {
            $filter: {
              input: '$$car.things',
              as: 'thing',
              cond: {
                $lte: [ '$$thing.cost', 10 ]
              }
            }
          }
        }
      }
    }
  }
}
])


Но он требует явного перечисления всех сохраняемых полей, список которых в реальной коллекции варьируется (неизвестен). Как быть?
  • Вопрос задан
  • 227 просмотров
Решения вопроса 1
Может Вам поможет $redact?
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы
STM Labs Нижний Новгород
от 50 000 ₽
NZT Group Москва
от 150 000 до 300 000 ₽
FunCorp Москва
от 200 000 ₽
29 нояб. 2020, в 22:37
500 руб./за проект
29 нояб. 2020, в 20:54
3000 руб./за проект
29 нояб. 2020, в 20:40
25000 руб./за проект