Bal*_*han 5 javascript mongoose mongodb node.js
我需要更新数组中的特定对象
{
"_id": "543e2f8e769ac100008777d0",
"createdDate": "2014-10-15 01:25 am",
"cancle": false,
"eventDateAndTime": "2014-02-12 12:55 am",
"eventstatus": true,
"userPhone": "44444444",
"userId": "54334def7e85de48638d1069",
"createdBy": "four",
"eventName": "real tea",
"__v": 0,
"friends": [
{
"phoneNumber": "11111111",
"userName": "one",
"userId": "54310801e2659ecc3650100b",
"status": 0
},
{
"phoneNumber": "22222222",
"userName": "two",
"userId": "54310814e2659ecc3650100c",
"status": 1
}
]
}
Run Code Online (Sandbox Code Playgroud)
我尝试了很多,我不知道我错过了什么。
event.update(
function(err, eventSaved) {
if(err) {
res.json({'err':err});
}
})
Run Code Online (Sandbox Code Playgroud)
我收到错误响应
err: {
name: "MongoError"
code: 66
err: "After applying the update to the document {_id: ObjectId('543e2ecb74d70100001545ad') , ...}, the (immutable) field '_id' was found to have been altered to _id: ObjectId('543e2f8e769ac100008777d0')"
}
Run Code Online (Sandbox Code Playgroud)
我也尝试过
event.update({'friends.userId': req.param.friendId}, {'$set': {
'friends.$.status': status }},
function(err, eventSaved, eve) {
if(err) {
}
})
Run Code Online (Sandbox Code Playgroud)
同样的错误。
请帮我弄清楚我缺少什么,
我什至尝试过这个
Events.findOneAndUpdate({_id: req.params.eventId}, {$set: {'friends[keyValue].status': 7 }}, {upsert: true, "new": false}).exec(function(err, thing) {
console.dir(thing);
});
Run Code Online (Sandbox Code Playgroud)
什么都不起作用。请帮我解决这个问题
谢谢,巴鲁
您可以尝试传递要更新的值中的 id 字段,就好像您通过传递要更新的值看到控制台一样,它附加了新的 _id 字段。所以尝试以下方式:
Events.findOneAndUpdate({_id: req.params.eventId}, {$set: {'friends[keyValue].status': 7, _id: req.params.eventId }}, {upsert: true, "new": false}).exec(function(err, thing) {
console.dir(thing);
});
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
4667 次 |
最近记录: |