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

Update in forEach auf der Mongodb-Shell

Um zu bekommen, was Sie wollen, brauchen Sie ein paar Dinge:

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

Also im Grunde müssen Sie Ihre Arrays vor dem Update "rekonstruieren"