Дана следующая структура объекта:
public class RootDocument
{
public Guid Id { get; set; }
public string SomeProperty { get; set; }
public List<ChildDocument> Documents { get; set; }
}
public class ChildDocument
{
public Guid Id { get; set; }
public string Name { get; set; }
public string SomeProperty { get; set; }
}
Я хочу обновить все ChildDocuments
указанного Id
на всех RootDocument
в коллекции RootDocument
.
Идея состоит в том, чтобы обновить их все в виде такой массовой операции:
var document = new ChildDocument() { Id = <id of existing ChildDocument>, Name = ..., ...);
var bulkOperations = new WriteModel<RootDocument>[]
{
new UpdateManyModel<RootDocument>(
Builders<RootDocument>.Filter.Eq("Documents.Id", document.id),
Builders<RootDocument>.Update.AddToSet(x => x.Documents, document))
};
await mongoDatabase.GetCollection<RootDocument>()
.BulkWriteAsync(bulkOperations, new BulkWriteOptions { IsOrdered = false });
Но AddToSet
не является операцией замены существующего ChildDocument
.
Как лучше всего реализовать это требование с помощью последней версии драйвера MongoDB C #?