我查找了一种与mongodb UpdateDefinitionBuilders
合作的方法,但documentation并没有显示出太多......
我需要能够动态构建我的更新查询,所以我想这样做:
var update = Builders<Product>.Update;
update.Set("add A update");
if ()
update.Set("add X update");
else
update.Set("add Y update");
update.Set("add B update");
if ()
update.Set("add Z update");
else
update.Set("add P update");
Collection.UpdateOneAsync(filter, update, updateOptions);
但它给出了编译错误:
cannot convert from UpdateDefinitionBuilder UpdateDefinition
我看了,但找不到解决方法如何使用此UpdateDefinitionBuilders
有人可以提供一个如何使用这个类的代码示例吗?
答案 0 :(得分:8)
如果您只需更新多个属性,可以在更新构建器上调用Set
,然后再调用Set
扩展方法。您可以使用lambda表达式或属性名称。
var update = Builders<Product>.Update
.Set(p => Name, "Name value")
.Set(p => Description, "Description value");
collection.UpdateOneAsync(filter, update, updateOptions);
如果您想要有条件地更新某些属性,您应该创建一个更新集合,然后将它们组合在一起:
var update = Builders<Product>.Update;
var updates = new List<UpdateDefinition<Product>>();
updates.Add(update.Set("propertyA", "add A update"));
if ()
updates.Add(update.Set("propertyX", "add X update"));
else
updates.Add(update.Set("propertyY", "add Y update"));
updates.Add(update.Set(p => p.PropertyB, "add B update"));
if ()
updates.Add(update.Set(p => p.PropertyZ, "add Z update"));
else
updates.Add(update.Set(p => p.PropertyP, "add P update"));
Collection.UpdateOneAsync(filter, update.Combine(updates), updateOptions);