文档菜单
文档首页
/ / /
Go 驱动
/ /

更新文档

您可以通过使用UpdateOne() 方法来更新集合中的文档。

提示

阅读用法示例 了解如何运行此示例。

以下示例在restaurants集合上执行以下操作:

  • 匹配具有特定_id的文档

  • 在匹配的文档中创建一个名为avg_rating的新字段,其值为4.4

coll := client.Database("sample_restaurants").Collection("restaurants")
id, _ := primitive.ObjectIDFromHex("5eb3d668b31de5d588f42a7a")
filter := bson.D{{"_id", id}}
// Creates instructions to add the "avg_rating" field to documents
update := bson.D{{"$set", bson.D{{"avg_rating", 4.4}}}}
// Updates the first document that has the specified "_id" value
result, err := coll.UpdateOne(context.TODO(), filter, update)
if err != nil {
panic(err)
}

查看一个完全可运行的示例。

运行完整示例后,您可以在restaurants集合中找到以下更新后的文档

// result truncated
{
"_id" : ObjectId("5eb3d668b31de5d588f42a7a"),
...
"name" : "Green House Cafe",
"restaurant_id" : "40372112",
"avg_rating" : 4.4
}

有关如何查找文档的示例,请参阅查找文档。

有关替换文档、指定查询过滤器以及处理潜在错误的更多信息,请参阅修改文档。

有关更新操作符的更多信息,请参阅MongoDB更新操作符参考文档。

UpdateOne()

返回

插入多个文档