MongoDB ondersteunt niet het soort voorwaardelijke update waarnaar u op zoek bent. U kunt echter nog steeds beter doen dan een zoek-, loop- en bewaarmethode te gebruiken.
Verplaats de conditiecontrole naar de update
queryselector en geef vervolgens twee updates uit (één voor elk geval), met behulp van {multi: true}
om de update toe te passen op alle overeenkomende documenten.
// Start with the "if" update
Documents.update(
{some_condition: true, "some field": "some condition"},
{$set: {"status": "value 1"}},
{multi: true},
function(err, numAffected) {
// Now do the "else" update, using $ne to select the rest of the docs
Documents.update(
{some_condition: true, "some field": {$ne: "some condition"}},
{$set: {"status": "value 2"}},
{multi: true},
function(err, numAffected) {
// All done.
}
)
}
)