Docs Menu
Docs Home
/ /

複数のドキュメントの更新

コレクション内の複数のドキュメントを更新するには、 インスタンスで update_many() Collectionメソッドを呼び出します。

次のパラメータをupdate_many()メソッドに渡します。

  • 一致する基準を指定するクエリフィルター

  • ドキュメントの更新 。一致するすべてのドキュメントに対する更新を指定します

update_many() メソッドは、変更されたドキュメントの数など、 更新操作の結果に関する情報を含む UpdateResult タイプを返します。

update_many()メソッドの詳細については、ドキュメントの修正 ガイドの「 ドキュメントのアップデート 」セクションを参照してください。

この例では、 sample_restaurantsデータベースのrestaurantsコレクション内のドキュメントをアップデートします。

次のコードでは、 address.streetフィールドの値が"Sullivan Street"であり、 boroughフィールドの値が"Manhattan"であるドキュメントにnear_meフィールドを追加します。

AsynchronousSynchronous各実行時に対応するコードを表示するには、 タブまたは タブを選択します。

use std::env;
use mongodb::{ bson::doc, Client, Collection };
use bson::Document;
#[tokio::main]
async fn main() -> mongodb::error::Result<()> {
let uri = "<connection string>";
let client = Client::with_uri_str(uri).await?;
let my_coll: Collection<Document> = client
.database("sample_restaurants")
.collection("restaurants");
let filter =
doc! {
"address.street": "Sullivan Street",
"borough": "Manhattan"
};
let update = doc! { "$set": doc! { "near_me": true } };
let res = my_coll.update_many(filter, update, None).await?;
println!("Updated documents: {}", res.modified_count);
Ok(())
}
// Your values might differ
Updated documents: 22
use std::env;
use mongodb::{
bson::{ Document, doc },
sync::{ Client, Collection }
};
fn main() -> mongodb::error::Result<()> {
let uri = "<connection string>";
let client = Client::with_uri_str(uri)?;
let my_coll: Collection<Document> = client
.database("sample_restaurants")
.collection("restaurants");
let filter =
doc! {
"address.street": "Sullivan Street",
"borough": "Manhattan"
};
let update = doc! { "$set": doc! { "near_me": true } };
let res = my_coll.update_many(filter, update, None)?;
println!("Updated documents: {}", res.modified_count);
Ok(())
}
// Your values might differ
Updated documents: 22

戻る

更新 1