MongoDB
 sql >> Base de données >  >> NoSQL >> MongoDB

Mise à jour dans forEach sur le shell mongodb

Pour obtenir ce que vous voulez, vous aurez besoin de quelques éléments :

t.forEach(function( aRow ) {
    var newFields = [];
    aRow.fields.forEach( function( aField ){
        var newItems = [];
        aField.items.forEach( function( item ){
            var aNewItem = { item: parseInt(item), ref: 0 };
            newItems.push( aNewItem );
        } );
        newFields.push({ _id: aField._id, items: newItems });
    } )
    aTable.update(
        { _id: aRow._id }, 
        { "$set": { "fields": newFields } }
    );
});

Donc, en gros, vous devez "reconstruire" vos tableaux avant de mettre à jour