MongoDB
 sql >> Datenbank >  >> NoSQL >> MongoDB

So überprüfen Sie, ob Mongos $addToSet ein Duplikat war oder nicht

Zumindest in der Shell kann man unterscheiden, ob das Dokument modifiziert wurde oder nicht (siehe 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 })

Update für Node

Wenn Sie collection.update(criteria, update[[, options], callback]); verwenden Sie können die Anzahl der geänderten Datensätze abrufen.

Aus dem Knoten docs

Ein weiteres Update

Es scheint, dass sich der native Mongo Node-Treiber zumindest in Version 1.4.3 nicht wie dokumentiert verhält. Es ist möglich, dies mithilfe der Massen-API (eingeführt in Mongo 2.6) zu umgehen:

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();
});