sql >> Databasteknik >  >> NoSQL >> MongoDB

Ändra ett befintligt objekt i en array men ändå bevara nyckelunikiteten

Det finns två villkor, tror jag:

var newName = "somename";
var oldName = "nick";
var newOption = 3;

// if not change the name
db.coll.update({
    _id : id,
    'profile_set.name' : oldName
}, {
    $set : {
        "profile_set.$.options" : newOption
    }
});

// if change the name
db.coll.update({
    _id : id,
    $and : [ {
        'profile_set.name' : {
            $ne : newName
        }
    }, {
        'profile_set.name' : oldName    
    } ]
}, {
    $set : {
        "profile_set.$.name" : newName,
        "profile_set.$.options" : newOption

    }
});



  1. Node.js Kue hur man startar om misslyckade jobb

  2. OverflowError:MongoDB kan bara hantera upp till 8-byte ints?

  3. Mongo ObjectIDs:Säker att använda i naturen?

  4. MongoDb frågearray med nollvärden