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

Comment effectuer plusieurs mises à jour d'un tableau imbriqué dans MondoDB ?

C'est parce que vous utilisez l'opérateur $ :L'opérateur positionnel $ identifie un élément (pas multi) dans un tableau à mettre à jour sans spécifier explicitement la position de l'élément dans le tableau. Pour projeter ou renvoyer un élément de tableau à partir d'une opération de lecture, consultez l'opérateur de projection $.

Vous pouvez utiliser le code ci-dessous pour le faire :

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