我在 nedb 中有以下数据。
["UserId":"1446943507761","UserName":"xxx","link":"xxx.html","taskDone":"false","id":14,"_id":"fdaaTWSxloQZdYlT"]
["UserId":"1446943507761","UserName":"xxx","link":"xxx.html","taskDone":"false","id":1,"_id":"fzh2cedAXxT76GwB"]
["UserId":"1446943507761","UserName":"xxx","link":"xxx.html","taskDone":"false","id":0,"_id":"k4loE7XR5gioQk54"]
我正在尝试更新 id 为 0 的行并将 taskDone 的值设置为 true。我使用以下查询将值设置为 true
db.taskmap.update({ _id: "k4loE7XR5gioQk54", UserName:"xxx" }, { $set: { taskDone: "true"} }, function (err, numReplaced) {
console.log("replaced---->" + numReplaced);
});
它会更新值,但会更新为新行。它基本上插入一个具有相同值的新行,除了 taskdone 值为 true。它不会删除现有数据。因此,在更新后的最终数据表中,我得到了 id 0 的两行,除了 taskDone 之外,所有值都相同。我不确定我是否做错了什么。如果有人能告诉我更新值的正确方法,那将会很有帮助。