猫鼬 findByIdAndUpdate 只更新文档中的一个字段

Sau*_*h B 4 mongoose mongodb node.js mongodb-query

当用户单击某个按钮并将他的stormpath用户ID(req.user.href)存储在一个数组中时,我试图增加upvotes。

尝试 1:

if (newUpvoters = found_post[0].upvoters.indexOf(req.user.href) == -1) {
    Problem.findByIdAndUpdate(found_post[0].id,  
        { $push: { upvoters:  req.user.href }}
        , {$inc: { upvotes : 1 } }, function (err, post) {
                if (err) return next(err);
                res.json(post);
    })
}
Run Code Online (Sandbox Code Playgroud)

结果: 只有 upvoters 数组被正确更新。赞成票不会增加。

尝试 2:

Problem.findByIdAndUpdate(found_post[0].id,  
    {$inc: { upvotes : 1 } }, 
    { $push: { upvoters:  req.user.href }}, function (err, post) {
        if (err) return next(err);
        res.json(post);
})
Run Code Online (Sandbox Code Playgroud)

结果: 只有 Upvotes 增加,upvoters 数组没有更新。

尝试 3:

Problem.findByIdAndUpdate(found_post[0].id,  
    {$set :
        {$inc: { upvotes : 1 } , 
         $push: { upvoters:  req.user.href }}
    }, function (err, post) {
        if (err) return next(err);
        res.json(post);     
     })
Run Code Online (Sandbox Code Playgroud)

结果:什么都没发生

我想要做什么:更新 Upvoters 数组并将 upvotes 增加 1。

Joh*_*yHK 5

您需要将$inc$push运算符都放入同一个对象中:

Problem.findByIdAndUpdate(found_post[0].id,  
    { $inc: { upvotes : 1 }, 
      $push: { upvoters:  req.user.href }
    }, function (err, post) {
        if (err) return next(err);
        res.json(post);
})
Run Code Online (Sandbox Code Playgroud)