如何在猫鼬中更新和删除数组中的项目?

时间:2020-10-07 10:02:55

标签: node.js mongodb express mongoose

我有一个棋盘对象,我想用快递和猫鼬对其进行编辑,这是我的对象:

"boardMembers": [
        "5f636a5c0d6fa84be48cc19d",
    ],
    "boardLists": [
        {
            "cards": [
                {
                    "_id": "5f7c9b77eb751310a41319ab",
                    "text": "card one"
                },
                {
                    "_id": "5f7c9bb524dd8d42d469bba3",
                    "text": "card two"
                }
            ],
            "_id": "5f7c9b6b02c19f21a493cb7d",
            "title": "list one",
            "__v": 0
        }
    ],
    "_id": "5f63877177beba2e3c15d159",
    "boardName": "board1",
    "boardPassword": "123456",
    "boardCreator": "5f636a5c0d6fa84be48cc19d",
    "g_createdAt": "2020-09-17T15:57:37.616Z",
    "__v": 46
}

现在这是我的代码,我尝试使用$ pull进行操作,但是在Postman上检查时什么也没发生

router.put("/delete-task/:list/:task", auth, boardAuth, async (req, res) => {
  const listId = req.params.list;
  const task = req.params.task;

  const board = await Board.findOne({ _id: req.board._id });
  if (!board) return res.status(404).send("no such board");

  Board.findOneAndUpdate(
    { _id: req.board._id },
    { $pull: { "boardLists.$[outer].cards": { _id: task } } },
    {
      arrayFilters: [{ "outer._id": listId }],
    }
  );
  await board.save();
  res.send(board);
});

我在这里想念什么?

1 个答案:

答案 0 :(得分:1)

希望这种方法适用于您的情况,您只需要将ID转换为mongo objectId。因此您的代码将如下所示:

import mongoose from "mongoose";

const task = mongoose.Types.ObjectId(req.params.task);
const listId = mongoose.Types.ObjectId(req.params.list);

board = await Board.findOneAndUpdate(
    { _id: req.board._id},
    { $pull: {
           "boardLists.$[outer].cards": { _id: task }
        }
    },
    {
      arrayFilters: [{ "outer._id": listId }],
      returnNewDocument: true
    }
);

res.send(board);