Docs 菜单
Docs 主页
/ / /
C#/.NET
/ / /

UpdateMany

在此页面上

  • Overview
  • 样本数据
  • 方法和参数
  • 更新多个值
  • 组合更新定义
  • 更新管道
  • 配置选项
  • 返回值
  • 更多信息
  • API 文档

在本指南中,您可以学习;了解如何使用MongoDB .NET/ C#驱动程序更新多个文档中的值。

.NET/ C#驱动程序提供以下方法来更新值:

  • UpdateMany():更新多个文档中的一个或多个字段。

  • UpdateManyAsync()UpdateMany() 的异步版本。

以下部分更详细地描述了这些方法。

注意

方法重载

此页面上的许多方法都有多个重载。本指南中的示例仅显示每种方法的一个定义。有关可用重载的更多信息,请参阅 API文档。

本指南中的示例使用 sample_restaurants 数据库中的 restaurants 集合。此集合中的文档使用以下 RestaurantAddressGradeEntry 类作为模型:

public class Restaurant
{
public ObjectId Id { get; set; }
public string Name { get; set; }
[BsonElement("restaurant_id")]
public string RestaurantId { get; set; }
public string Cuisine { get; set; }
public Address Address { get; set; }
public string Borough { get; set; }
public List<GradeEntry> Grades { get; set; }
}
public class Address
{
public string Building { get; set; }
[BsonElement("coord")]
public double[] Coordinates { get; set; }
public string Street { get; set; }
[BsonElement("zipcode")]
public string ZipCode { get; set; }
}
public class GradeEntry
{
public DateTime Date { get; set; }
public string Grade { get; set; }
public float? Score { get; set; }
}

注意

restaurants集合中的文档使用蛇形命名规则。本指南中的示例使用 ConventionPack 将集合中的字段反序列化为 Pascal 语句,并将它们映射到 Restaurant 类中的属性。

如需了解有关自定义序列化的更多信息,请参阅自定义序列化

此数据集来自 Atlas 提供的示例数据集。请参阅快速入门,以了解如何创建一个免费的 MongoDB 集群并加载这些示例数据。

UpdateMany()UpdateManyAsync() 方法接受以下参数:

Parameter
说明

filter

update

UpdateDefinition类的一个实例。该对象指定更新操作的类型、要更新的字段以及每个字段的新值。要学习;了解如何创建UpdateDefinition 对象,请参阅更新字段和更新数组。

数据类型: UpdateDefinition<TDocument>

options

可选。指定更新操作配置的UpdateOptions 类的实例。默认值为null 。有关可用选项的列表,请参阅配置选项。

数据类型: UpdateOptions

cancellationToken

可选。可用于取消操作的令牌。

数据类型CancellationToken

UpdateMany()UpdateManyAsync() 方法只接受一个 UpdateDefinition对象。以下部分介绍如何在单个方法调用中更新多个值。

Builders.Update.Combine() 方法允许您组合多个 UpdateDefinition 对象。此方法接受以下参数:

Parameter
说明

updates

要组合的更新定义的大量。

数据类型: UpdateDefinition<TDocument>[]

Combine() 方法返回定义多个更新操作的单个 UpdateDefinition对象。

以下代码示例使用Combine() 方法来组合 $ 设立操作和 $unset 操作:

var filter = Builders<Restaurant>.Filter
.Eq("cuisine", "Pizza");
var combinedUpdate = Builders<Restaurant>.Update.Combine(
Builders<Restaurant>.Update.Set("cuisine", "French"),
Builders<Restaurant>.Update.Unset("borough")
);
_restaurantsCollection.UpdateMany(filter, combinedUpdate);
var filter = Builders<Restaurant>.Filter
.Eq("cuisine", "Pizza");
var combinedUpdate = Builders<Restaurant>.Update.Combine(
Builders<Restaurant>.Update.Set("cuisine", "French"),
Builders<Restaurant>.Update.Unset("borough")
);
await _restaurantsCollection.UpdateManyAsync(filter, combinedUpdate);

如果您的应用程序连接到MongoDB Server4.2 或更高版本,则可以将一系列更新操作联接到单个聚合管道中。

要创建更新管道,请调用 Builders.Update.Pipeline() 方法。此方法接受以下参数:

Parameter
说明

pipeline

代表更新管道的 PipelineDefinition实例。要创建 PipelineDefinition对象,请为要执行的每个更新操作创建一个BSON文档,然后将这些文档传递给 PipelineDefinition.Create() 方法。

数据类型: PipelineDefinition<TDocument, TDocument>

Pipeline() 方法返回定义多个聚合阶段的单个 UpdateDefinition对象。

以下代码示例使用Pipeline() 方法来组合 $ 设立操作和 $unset 操作:

var filter = Builders<Restaurant>.Filter
.Eq("cuisine", "Pizza");
var updatePipeline = Builders<Restaurant>.Update.Pipeline(
PipelineDefinition<Restaurant, Restaurant>.Create(
new BsonDocument("$set", new BsonDocument("cuisine", "French")),
new BsonDocument("$unset", "borough")
)
);
_restaurantsCollection.UpdateMany(filter, updatePipeline);
var filter = Builders<Restaurant>.Filter
.Eq("cuisine", "Pizza");
var updatePipeline = Builders<Restaurant>.Update.Pipeline(
PipelineDefinition<Restaurant, Restaurant>.Create(
new BsonDocument("$set", new BsonDocument("cuisine", "French")),
new BsonDocument("$unset", "borough")
)
);
await _restaurantsCollection.UpdateManyAsync(filter, updatePipeline);

注意

不支持的操作

更新管道不支持所有更新操作,但它们支持其他更新定义中未找到的某些聚合阶段。有关管道支持的更新操作列表,请参阅MongoDB Server手册中的使用聚合管道进行更新。

UpdateMany()UpdateManyAsync() 方法可以选择接受 UpdateOptions对象作为参数。您可以使用此参数来配置更新操作。

UpdateOptions 类包含以下属性:

UpdateMany() 方法返回 UpdateResultUpdateManyAsync() 方法返回 Task<UpdateResult>对象。 UpdateResult 类包含以下属性:

属性
说明

IsAcknowledged

指示更新操作是否由 MongoDB 确认。

数据类型: bool

IsModifiedCountAvailable

指示您是否可以读取 UpdateResult 上的更新记录计数。

数据类型: bool

MatchedCount

与查询过滤匹配的文档数量,无论文档是否已更新。

数据类型: long

ModifiedCount

更新操作更新的文档数。

数据类型: long

UpsertedId

如果驱动程序执行了更新或插入,则在数据库中更新或插入的文档的 ID。

数据类型: BsonValue

本页包括一个简短的交互式实验室,演示了如何使用 UpdateManyAsync() 方法修改数据。无需安装 MongoDB 或代码编辑器,即可直接在浏览器窗口中完成此实验。

若要启动实验室,请单击页面顶部的“Open Interactive Tutorial”按钮。要将实验室扩展为全屏格式,请单击实验室窗格右上角的全屏按钮 ()。

有关更新操作的可运行示例,请参阅更新多个文档页面。

要了解创建查询筛选器的更多信息,请参阅指定查询指南。

有关本指南中讨论的任何方法或类型的更多信息,请参阅以下API文档:

后退

数组