使用PUT和update()mongoose递增JSON字段

Incrementing JSON field using PUT and update() mongoose

本文关键字:mongoose 递增 JSON 字段 PUT update 使用      更新时间:2023-09-26

我试图简单地将1添加到存储在JSON文件中的变量中。

这就是我用来实现这一目标的方法:

app.put('/api/listing/:street/:buildingNumber/:apartmentNumber/incrementFlagCount', function (req, res) {
        console.log("incrementing flag count now");
        mongoose.model('Listing').findOne(req.street, req.buildingNumber, req.apartmentNumber, function(err, listing){
            listing.update({
             //   $inc : {flagCount : 1}
                flagCount : flagCount+1
            },function(err){
                if(err){
                    res.send("There was a problem incrementing the flagCount of a listing: " + err);
                }
                else{
                    console.log("Flag count after=" + listing.flagCount);
                    res.json(listing.flagCount);
                }
            })
        });
    });

我得到以下错误:ReferenceError: flagCount is not defined这就是mongolab:中JSON的外观

{
    "_id": {
        "$oid": "566c4bbabcda51a9eef08578"
    },
    "street": "test",
    "buildingNumber": 1,
    "apartmentNumber": 1,
    "beds": 1,
    "price": 1,
    "flagCount": 3,
    "owner": "56472a83bd9fa764158d0cb6"
}

我做错了什么?我只想把flagCount加1。

您使用flagCount对findOneupdate的调用不正确。CCD_ 5需要一个条件对象。

您还应该使用req.params.street而不是req.street等。

与其先查找然后更新,不如使用findOneAndUpdate?

mongoose.model('Listing').findOneAndUpdate({street: req.params.street, 
buildingNumber: req.params.buildingNumber,
apartmentNumber: req.params.apartmentNumber}, {$inc: {flagCount: 1}}, 
    function(err, listing) {
     /// do stuff 
})