簡體   English   中英

我的代碼有什么問題? 如何從MongoDB中刪除一個集合?

[英]What is the problem in my code? How to delete a collection from MongoDB?

我正在嘗試使用 postmap API 從 mongodb 中刪除一個集合。下面是我的代碼。更新 function 工作正常。但是,刪除 function 不工作。 它顯示內部服務器錯誤。我不知道為什么?

const router = require("express").Router();
const User = require("../models/User");
const bcrypt = require("bcrypt");
//uodate
router.put("/:id", async (req, res) => {
    if ((req.body.userId === req.params.id) || req.body.isAdmin) {
        if (req.body.password) {
            try {
                const salt = await bcrypt.genSalt(10);
                req.body.password = await bcrypt.hash(req.body.password, salt);
            }
            catch (err) {
                return res.status(500).json(err);
            }
        }
        try {
            const user = await User.findByIdAndUpdate(req.params.id, {
                $set: req.body,
            });
           return res.status(200).json("Account has been updated");
        }
        catch (err) {
            return res.status(500).json(err);
        }
    }
    else return req.status(400).json("You can only update your account!!!");
});
//delete
router.delete("/:id", async (req, res) => {
    if ((req.body.userId === req.params.id) || req.body.isAdmin) {
        try {
           await User.deleteOne(req.params.id);
            return res.status(200).json("Account has been deleted");
        }
        catch (err) {
            return res.status(500).json(err);
        }
    }
    else return res.status(400).json("You can only update your account!!!");
});



module.exports = router;

幫我看看這張postman API 截圖

您正在使用deleteOne()方法。 如果你想刪除整個集合,你應該使用deleteMany()方法:

await User.deleteMany({});

Model.deleteOne方法需要一個過濾器 object,例如{name: "value'"} 您正在傳遞req.params.id這是一個字符串。 如果你挖掘出錯誤的全文,它可能會抱怨該字符串不是 object。

您可能打算使用Model.findByIdAndDelete方法,例如

await User.findByIdAndDelete(req.params.id);

嘗試這個:

 await User.deleteOne({_id:req.params.id});

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM