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

Wie kann man ein Filialdokumentfeld in Mongodb dynamisch $festlegen?

Das habe ich herausgefunden.

Im Wesentlichen müssen Sie ein „Platzhalter“-Objekt des Unterdokuments erstellen, das Sie aktualisieren möchten, bevor Sie die Abfrage ausführen, etwa so:

var projectID = 'JKS78678923SDFD678';

var key = 'Three';
var value = 'Three';

var placeholder = {};
placeholder['options.' + key] = value;

Teams.findAndModify({
    query: {
        projectID:mongojs.ObjectId(projectID)
    },
    update: {
        $set : placeholder
    },
    upsert: true,
    multi: false,
    new: true
},
function(error, result, lastErrorObject){

    console.log(result);

});

Dadurch werden alle bereits vorhandenen Felder aktualisiert und das Feld/Wert-Paar erstellt, falls es noch nicht vorhanden war.