I have a document with the following fields:
{
"_id": 1,
"codes": [
{"name": "code1", "active": null, "disabled": false},
{"name": "code2", "active": null, "disabled": false},
{"name": "code3", "active": null, "disabled": false},
{"name": "code4", "active": null, "disabled": false},
{"name": "code5", "active": null, "disabled": false},
{"name": "code6", "active": null, "disabled": false}
]
}
Is there any way to update just the objects that have the name value equal to "code2", "code3" and "code4"?
For example:
db.collection.update(
{"_id": 1},
{
$set: {
"codes": [
{"name": "code2", "active": false, "disabled": true},
{"name": "code3", "active": true, "disabled": false},
{"name": "code4", "active": null, "disabled": true}
]
}
}
)
Expected result:
{
"_id": 1,
"codes": [
{"name": "code1", "active": null, "disabled": false},
{"name": "code2", "active": false, "disabled": true},
{"name": "code3", "active": true, "disabled": false},
{"name": "code4", "active": null, "disabled": true},
{"name": "code5", "active": null, "disabled": false},
{"name": "code6", "active": null, "disabled": false}
]
}
Actual result:
{
"_id": 1,
"codes": [
{"name": "code2", "active": false, "disabled": true},
{"name": "code3", "active": true, "disabled": false},
{"name": "code4", "active": null, "disabled": true}
]
}