MongoDB
 sql >> Database >  >> NoSQL >> MongoDB

Come eseguire l'aggiornamento multiplo di un array nidificato in MondoDB?

È perché stai usando l'operatore $:l'operatore $ posizionale identifica un elemento (non multi) in una matrice da aggiornare senza specificare esplicitamente la posizione dell'elemento nella matrice. Per proiettare o restituire un elemento dell'array da un'operazione di lettura, vedere l'operatore di proiezione $.

Puoi usare il codice qui sotto per farlo:

db.playground.find({
  $and: [
    {
      "TargetSegments.Colors": {
        $exists: true
      }
    },
    {
       "ProjectFileId": 1
    },
    {
      "SourceLanguageId": 2
    },
    {
      "TargetSegments": {
        $elemMatch: {
          "LanguageId": 1
        }
      }
    }
  ]
}).forEach(function(item)
{
    var targets = item.TargetSegments;

    for(var index = 0; index < targets.length; index++)
    {
        var target = targets[index];
        target.Segment = null,
        target.Colors= [],
        target.Widths= [],
        target.Heights= []
    }

    db.playground.save(item);
});