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。
您需要将$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)
| 归档时间: |
|
| 查看次数: |
5409 次 |
| 最近记录: |