Привет ребята. Подскажите пожалуйста, у меня есть коллекция Orders. [

{
"id": 1,
"totalPrice": 500,
"books": [
{
"_id": 123,
"title": "some"
},
{
"_id": 222,
"title": "2222"
}
]
},
{
"id": 2,
"totalPrice": 400
"books": [
{
"_id": 123,
"title": "some"
},
{
"_id": 333,
"title": "3333"
}
]
}
]
Мне нужно сделать выборку такую, чтобы на выходе получить:
[
{
"id": 1,
"totalPrice": 500,
"books": [
{
"_id": 123,
"title": "some"
}
]
},
{
"id": 2,
"totalPrice": 400
"books": [
{
"_id": 123,
"title": "some"
}
]
}
]
Тоесть сделать как-бы фильтрацию по id в каждом массиве books
Я пытался сделать так:
db.collection.find({
"books": {
"$elemMatch": {
"_id": 123
}
}
})
Но не работает, подскажите пожалуйста, как можно пофиксить?

5 ответов

12 просмотров

Попробуй просто "books._id" : 123

Vadym- Автор вопроса
Vadym
нет, выдача такая же

Ааа, не заметил что фильтрация нужна.

Vadym
нет, выдача такая же

Тогда агрегации и это https://docs.mongodb.com/manual/reference/operator/aggregation/filter/

Vadym- Автор вопроса

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

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

Но, может, есть уже проверенная? Наши требования такие: 1. Сообщения должны приходить из Инста в CRM оду 2. Должна быть возможность подключить несколько экаунтов Инстаграм. Р...
Alexander Sharoiko MSE / Александр Шаройко
8
Это может быть все-таки не флудвейт? у меня ботфазер принимает изменения и отображает даже что они изменились, на видео видно что он прислал якобы уже измененное описание, н...
OVERLINK
13
Я правильно понимаю что нет способов получить список ожидающих заявок на вступление в группу с помощью бота из mtproto?
Шамиль Прилов
7
Добрый день. Мне посоветовали обратиться к вам в чат за помощью. Ситуация описана на скрине. Как мне сказали, мне на бота навесили флудвейт. Есть ли возможность снять его ра...
OVERLINK
7
всем привет помогите пожалуйста используя CDN (GCP) у игроков из вьетнама загружается конфиг (размер 999 bytes) загружается 5 и более минут н а других CDN сервисах такой пробл...
Andrew Krw.
1
Просто по очереди выпиливаешь на ручной маппинг? По методу за раз
Andrii Kurdiumov
7
Приветствую. А не подскажете какие ограничения есть на использования api метода setMyName ? Несколько раз сменил имя бота и получил бан на 2 месяца на смену имени.
Slick Slack
8
Привет, коллеги! Возникла задача ограничить максимальный размер вложений для определённых расширений, например, чтобы для изображений лимит был 10 МБ, а для видео — 100 МБ. Ог...
Andro
1
Всем привет! Взялся портировать модули на 18 версию, лезет _logger.log(log_level, 'no translation language detected, skipping translation %s', frame, stack_info=True) А чт...
Max Lit
3
Доброе утро, а кто то делал Google аналитику через php ? curl_setopt($ch, CURLOPT_NOSIGNAL, true); Это должно быть async без ожидания ответа. Вообще php нормально с таким с...
Max Dubovsky
9
Карта сайта