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

How to remove a subdocument from a document, WHERE condition x = true OR condition y = true?

本文关键字:true 文档 条件 删除      更新时间:2023-09-26

下面是一个名为Bets的引用子文档,它嵌入到另一个名为Users的模型的属性数组中。当用户删除好友时,与该特定用户相关的所有下注也应从user文档中删除(该用户与现在已删除的其他用户是好友)。

我正在寻找这样做的查询。首先,这里是特定的bet实例。

{
    "_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

您可能必须在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.
});