如何从文档中删除子文档,WHERE条件x = true或条件y = true?

时间:2016-11-01 15:07:33

标签: javascript node.js mongodb mongoose mongodb-query

下面是一个名为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

1 个答案:

答案 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.

});