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

Der Mongo C#-Treiber aktualisiert ein bestimmtes Element in einem verschachtelten Array

Sie benötigen Positionsoperator $ Hier können Sie eine Bedingung auf Dokumentebene und eine Bedingung auf Arrayebene angeben, um ein einzelnes verschachteltes Element in einem Array eines bestimmten Dokuments zu finden. In C# $ Zeichen wird durch -1 dargestellt als Index Ihres Modellarrays übergeben. Versuchen Sie:

var col = mydb.GetCollection<Document>("collectionName");
var id = new ObjectId("5babaaf5509f6d342da5abaa");
var elementName = "Car";
var newValue = 2;

var filterBuilder = Builders<Document>.Filter;
var filter = filterBuilder.Eq(x => x.Id, id) &
    filterBuilder.ElemMatch(doc => doc.Elements, el => el.Name == elementName);

var updateBuilder = Builders<Document>.Update;
var update = updateBuilder.Set(doc => doc.Elements[-1].Value, newValue);

Col.UpdateOne(filter, update);