C#MongoDB驱动程序 - 如何使用UpdateDefinitionBuilder?

时间:2018-03-18 10:06:30

标签: mongodb mongodb-.net-driver

我查找了一种与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

有人可以提供一个如何使用这个类的代码示例吗?

1 个答案:

答案 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);