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

Mettre à jour le tableau avec plusieurs conditions dans mongodb

Lorsqu'il y a plusieurs conditions à faire correspondre à l'intérieur d'un tableau, le .Dot la notation ne fonctionne pas avec la requête de mise à jour.

Vous devez utiliser $elemMatch pour faire correspondre exactement deux champs à l'intérieur d'un tableau

db.getCollection('test').updateOne(
  {
    "_id": ObjectId("5b673f525ef92ec6ef16504e"),
    "events": { "$elemMatch": { "name": "Winner", "map": 2 }}
  },
  {
    "$push": { "events.$.something": { "something": "test" }}
  }
)