MongoDB
 sql >> база данни >  >> NoSQL >> MongoDB

Промяна на съществуващ обект в масив, но запазване на уникалността на ключа

Мисля, че има две условия:

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. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Mongoose unshift findAndUpdateById

  2. Журналирането на MongoDB гарантира ли издръжливост?

  3. MongoDb - Как мога да актуализирам множество елементи на вложен обект с помощта на $set?

  4. Неуспешно зареждане на c++ bson разширение, използвайки чиста JS версия

  5. Spring Data MongoDB Търсене с Pipeline Aggregation