下面是一个名为Bets的引用子文档,它嵌入到另一个名为Users的模型的属性数组中。当用户删除朋友时,也应该从用户文档中删除与该特定用户的所有关联投注(与现在已删除的其他用户成为朋友的用户)。
我正在寻找这样做的查询。首先,这是特定的投注实例。
{
"_id" : ObjectId("5817cc81233ef74d418d5a1f"),
"amount" : 50,
"name" : "Redskins vs Cowboys",
"description" : "let's see who wins this game",
"status" : "requested",
"requestee" : {
"user" : ObjectId("5817a417146dbb4b380ad1b2"),
"winnerVote" : null
},
"requestor" : {
"user" : ObjectId("5817a41e146dbb4b380ad1b3"),
"winnerVote" : null
},
"__v" : 0
}
到目前为止,这是我的破坏友谊控制者:
destroy: function(req, res) {
User.findByIdAndUpdate(req.params.id,
{ $pull: { "friendships": {"friend": req.params.friendId } }, $pull: { "bets": {"requestee.id": req.params.friendId ****OR**** "requestor.id": req.params.friendId}} }, function(err, user) {
if (err) {
res.send({error: err});
} else {
User.findByIdAndUpdate(req.params.friendId,
{ $pull: { "friendships": {"friend": req.params.id } } }, function(err, user) {
if (err) {
res.send({error: err})
} else {
res.status(200).send();
}
}
)
}
})
}
如您所见,在第一次'findByIDandUpdate'
查询后,我有两个$pull
命令。第二个是我试图实现我想要生成的新查询的地方。
我想拉下注,其中bet.requesteEE.user === oldFriendID
或(||)拉下注,其中bet.requestOR.user === oldFriendID
答案 0 :(得分:0)
您可能必须在Mongoose回调中处理此问题 - 看看是否有效:
User.findById(req.params.id, function(err, user) {
// for each bet in user.bets
user.bets.forEach(function(bet) {
if (bet.requestee === friendId || bet.requester === friendId) {
delete bet;
}
});
user.save();
// Handle response logic here or in the save callback.
});