sql >> Database >  >> NoSQL >> MongoDB

Update in forEach op mongodb shell

Om te krijgen wat je wilt, heb je een paar dingen nodig:

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

Dus eigenlijk moet je je arrays "reconstrueren" voordat je gaat updaten



  1. Mongoose subdocument zoeken/bijwerken

  2. Flask - Bad Request De browser (of proxy) heeft een verzoek verzonden dat deze server niet kon begrijpen

  3. Kan redis mysql volledig vervangen?

  4. 2 manieren om een ​​verzameling in MongoDB te verwijderen