使用Mongoose更新数组中的特定对象时出错

时间:2014-10-17 07:54:05

标签: javascript node.js mongodb mongoose

我需要更新数组中的特定对象

{
    "_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
        }
    ]
}

我尝试了很多,我不知道我错过了什么。

event.update(
                    function(err, eventSaved) {
                    if(err) {
                 res.json({'err':err});
                    }
                })

我收到错误回复

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')"
}

我也试过

event.update({'friends.userId': req.param.friendId}, {'$set': {
                    'friends.$.status': status }},
                    function(err, eventSaved, eve) {
                    if(err) {

                    }
                })

同样的错误。

请帮我弄清楚我错过了什么,

我甚至试过这个

Events.findOneAndUpdate({_id: req.params.eventId}, {$set: {'friends[keyValue].status': 7 }}, {upsert: true, "new": false}).exec(function(err, thing) {
                    console.dir(thing);
                });

没有任何作用。请帮我弄清楚问题

谢谢, 巴鲁

3 个答案:

答案 0 :(得分:1)

使用update()mongoose方法意味着您要更新所有字段,包括在Mongo中不可变的_id字段。这导致抛出该错误。

event.update(function(err, eventSaved) {
                    if(err) {
                 res.json({'err':err});
                    }
                })

因此,请初始化您的事件模型并更改属性并使用save()方法。

event.save(function(err, eventSaved){
 //some code here
})

答案 1 :(得分:0)

您可以尝试将值中的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);
            });

答案 2 :(得分:0)

这不是一个大问题,它是由于为模态保存新对象而引起的。 只需将对象保存在某些var。

前: -

router.put('/brand/:id', function (req, res) {
    var brand = {
        Name: req.body.Name,
        Description: req.body.Description,
        Date_Modify: moment()
    };
            Brand.findByIdAndUpdate(req.params.id, brand, {
                new: true
            }, function (error, doc) {
                if (error) {
                    if (error.code == 11000) {
                        res.json({
                            success: false,
                            message: 'Update Failed ,Brand Name Already Exist.'
                        });
                    } else {
                        res.json({
                            success: false,
                            message: error
                        });
                    }
                } else if (doc) {
                    res.json({
                        success: true,
                        status: res.statusCode,
                        message: 'Brand Updated Successfully.',
                        data: doc
                    });
                } else {
                    res.json({
                        success: false,
                        status: 404,
                        message: 'Brand Not Found.',
                        data: doc
                    });
                }
            });
        });

您可以通过它解决问题。

实际上在创建对象时它会创建一个新对象(_id),因此无法保存新的id。