Non è possibile modificare più elementi della matrice in un'unica operazione di aggiornamento. Pertanto, dovrai ripetere l'aggiornamento per migrare i documenti che richiedono la modifica di più elementi dell'array. Puoi farlo scorrendo ogni documento nella raccolta, applicando ripetutamente un aggiornamento con $elemMatch
fino a quando il documento non avrà sostituito tutti i relativi commenti, ad es.:
db.collection.find().forEach( function(doc) { do { db.collection.update({_id: doc._id, comments:{$elemMatch:{user:"test", avatar:{$ne:"new_avatar.jpg"}}}}, {$set:{"comments.$.avatar":"new_avatar.jpg"}}); } while (db.getPrevError().n != 0); })
Tieni presente che se l'efficienza di questa operazione è un requisito per la tua applicazione, dovresti normalizzare il tuo schema in modo tale che la posizione dell'avatar dell'utente sia archiviata in un unico documento, anziché in ogni commento.