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

Как да проверите дали $addToSet на Mongo е дубликат или не

Поне в обвивката можете да разграничите дали документът е бил модифициран или не (вижте nModified ).

> db.test4.update({_id:2}, {$addToSet: {tags: "xyz" }})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })

> db.test4.update({_id:2}, {$addToSet: {tags: "xyz" }})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 0 })

Актуализация за Node

Когато използвате collection.update(criteria, update[[, options], callback]); можете да извлечете броя на записите, които са били променени.

От възела документи

Друга актуализация

Изглежда поне във версия 1.4.3 родният драйвер на Mongo Node не се държи както е документирано. Възможно е да се заобиколи с помощта на груповия API (въведен в Mongo 2.6):

var col = db.collection('test');
// Initialize the Ordered Batch
var batch = col.initializeOrderedBulkOp();
batch.find({a: 2}).upsert().updateOne({"$addToSet": {"tags": "newTag"}});
// Execute the operations
batch.execute(function(err, result) {
  if (err) throw err;
  console.log("nUpserted: ", result.nUpserted); 
  console.log("nInserted: ", result.nInserted); 
  console.log("nModified: ", result.nModified); // <- will tell if a value was added or not
  db.close();
});


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Заявка Mongoose, където стойността не е нула

  2. Мониторинг на база данни без агент с ClusterControl

  3. Spring Data Mongo:upsert с различни актуализирани полета

  4. Как да стартирам SlaveOk в Mongoose?

  5. променлива с mongodb точка