簡體   English   中英

根據條件使用 Mongoose 更新文檔

[英]Updating a document with Mongoose based on a condition

所以我有這個任務模型:

const mongoose = require("mongoose");
const Schema = mongoose.Schema;


const taskSchema = new Schema({
    name: String,
    state: Number,
    created: {type: Date, default: Date.now}
})

const Task = mongoose.model("Task", taskSchema);
module.exports = Task;

我正在嘗試找到一種從 API 更新其狀態的方法(使用 Express 服務)

router.route("/:id").patch((req, res) => {
  console.log(req.body)
  const id = req.params.id
  Task.findOne({ _id: id })
  .then((task)=> {
    if (task.state === 0) {
      Task.findOneAndUpdate({ _id: id, state: 0 })
    } else {
      Task.findOneAndUpdate({ _id: id, state: 1 })
    }
  })
  .then(data => { res.status(200).json(data) })
  .catch(err => res.status(404).json("Error" + err));
});

我在這里做錯了什么? 文件沒有變化

如果您嘗試查找任務狀態為 0 且 id 為 req.params.id 是提供的 _id 的位置,請嘗試以下操作:

 router.route("/:id").patch(async (req, res) => { console.log(req.body) const id = req.params.id await Task.findOne({ _id: mongoose.Types.ObjectId(id) }) .then((task) => { if (task.state === 0) { Task.findOneAndUpdate({ _id: mongoose.Types.ObjectId(id), state: 0 }) } else { Task.findOneAndUpdate({ _id: mongoose.Types.ObjectId(id), state: 1 }) } }) .then(data => { res.status(200).json(data) }) .catch(err => res.status(404).json("Error" + err)); });

這個問題可能是對象 id "_id" 不匹配,因為這個req.params.id變量將作為字符串返回,但將其包裝在 mongoose.Types.ObjectId mongoose.Types.ObjectId(id)中會有所幫助。

我通過這樣做解決了它:

router.route("/:id").patch((req, res) => {
  const id = req.params.id
  Task.findOne({
      _id: mongoose.Types.ObjectId(id)
    })
    .then((task) => {
      if (task.state === 0) {
        task.state = 1
        task.save()
        res.status(200).json(task)
      } else {
        task.state = 0
        task.save()
        res.status(200).json(task)
      }
    })
});

暫無
暫無

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

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