Probeer de volgende code:
db.collection.find(your_querry).forEach(function(doc) {
doc.field1 = doc.field2.length;
db.collection.save(doc);
});
Je kunt your_querry
. gebruiken om slechts een deel van de originele collectie te selecteren, voert u een update uit. Als je een hele verzameling wilt verwerken, gebruik dan your_querry = {}
.
Als u wilt dat alle bewerkingen atomair zijn, gebruikt u update
in plaats van save
:
db.collection.find( your_querry, { field2: 1 } ).forEach(function(doc) {
db.collection.update({ _id: doc._id },{ $set: { field1: doc.field2.length } } );
});