Опитайте следния код:
db.collection.find(your_querry).forEach(function(doc) {
doc.field1 = doc.field2.length;
db.collection.save(doc);
});
Можете да използвате your_querry
за да изберете само част от оригиналната колекция, извършете актуализация. Ако искате да обработите цяла колекция, използвайте your_querry = {}
.
Ако искате всички операции да бъдат атомарни, използвайте update
вместо save
:
db.collection.find( your_querry, { field2: 1 } ).forEach(function(doc) {
db.collection.update({ _id: doc._id },{ $set: { field1: doc.field2.length } } );
});