猫鼬保存方法可多次保存同一文档

时间:2019-06-14 10:21:42

标签: node.js mongoose

嗨,我在角度UI上有一个输入字段日期选择器。我从字段中选择日期,并更新开始日期,直到它可以正常工作为止。但是如果我再次选择日期,它将复制该文档而不是对其进行更新。

工作代码:

router.post('/request/waiting/:startingDate', (req, res) => {
  const waiting = new WaitingRequest({
    startingDate: req.params.startingDate,
    requestID: req.body.requestID,
    contactInformation: req.body.contactInformation,
    orderInformation: req.body.orderInformation,
    requestInformation: req.body.requestInformation,
    installations: req.body.installations
  });
  waiting.save().then(result => {
    return res.status(201).json({
      message: 'Updated and Saved /waiting',
      result: result
    });
  });
});

到目前为止我已经尝试过,但是返回null:

router.post('/request/waiting/:startingDate', (req, res) => {
  WaitingRequest.findOneAndUpdate({
    requestID: req.body.requestID
  }, {
    startingDate: req.params.startingDate
  }).then(result => {
    console.log(result)
    if (result) {
      return res.status(201).json({
        message: 'Updated and saved',
        result: result
      });
    } else {
      return res.status(404).json({
        message: "404 Request Not Found"
      })
    }
  })
});

3 个答案:

答案 0 :(得分:1)

使用UpdateOne()猫鼬方法更新您的数据,

router.post('/request/waiting/:startingDate', (req, res) => {
    let query = { requestID: req.body.requestID }
    let update = { $set: { startingDate: new Date(req.params.startingDate) } }
    WaitingRequest.updateOne(query, update,(error,result)=>{
        if(error) return res.status(404).json({ message: "404 Request Not Found" })
        return res.status(201).json({
            message: 'Updated and saved',
            result: result
        });
    })
});

答案 1 :(得分:0)

您必须在findOneAndUpdate中使用$ set子句

编辑:改进代码以使用Promise并发送Date对象作为开始日期

尝试一下:

data

答案 2 :(得分:0)

出现404错误的原因是findOneAndUpdate无法根据requestID找到所需的文档。唯一缺少的难题是

  

new:布尔-如果为true,则返回修改后的文档,而不是   原版的。默认为false(在4.0中更改)

router.post('/request/waiting/:startingDate', (req, res) => {

  WaitingRequest.findOneAndUpdate({
    requestID: req.body.requestID
    }, { $set: {
       startingDate: new Date(req.params.startingDate)
    }, {
       upsert:true, new: true,
    },
  }).then(result => {
       return res.status(201).json({
        message: 'Updated and saved',
        result: result
      })
  }).catch(error => {
       res.send({ error })
   })
});

Reference: mongoose docs

希望这能回答您的问题。