Можете да използвате $ търсене с конвейер започвайки от MongoDB v3.6 ,
- нека предаде localField
_idкатоmodel_idпроменлива, можете да използвате полето вътре в тръбопровода за търсене, като използвате препратка $$, - тръбопровод за поставяне на
$matchетап и съответства на вашите изисквани условия иuser_idсъстояние
{
$lookup: {
from: "bookmarks",
let: { model_id: "$_id" },
pipeline: [
{
$match: {
$expr: { $eq: ["$$model_id", "$model_id"] },
user_id: objectId(req.user._id)
}
}
],
as: "bookmarks"
}
}
Друга опция за MongoDB v3.4 ,
- $filter
за повторение на цикъл от
bookmarksи получавате филтрирани отметки въз основа на условие
{
$lookup: {
from: "bookmarks",
localField: "_id",
foreignField: "model_id",
as: "bookmarks"
}
},
{
$addFields: {
bookmarks: {
$filter: {
input: "$bookmarks",
cond: { $eq: ["$$this.user_id", objectId(req.user._id)] }
}
}
}
}