{
"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
}
}
})
Но не работает, подскажите пожалуйста, как можно пофиксить?
Попробуй просто "books._id" : 123
нет, выдача такая же
Ааа, не заметил что фильтрация нужна.
Тогда агрегации и это https://docs.mongodb.com/manual/reference/operator/aggregation/filter/
спасибо, буду разбираться
Обсуждают сегодня