コレクションに複数のドキュメントを挿入するには、Collectionインスタンスで insert_many() メソッドを呼び出します。
1 つ以上のドキュメントを含むベクトルをinsert_many()メソッドに渡して、コレクションに挿入します。 These documents must be instances of the type that you parameterized your Collection instance with. たとえば、コレクションをMyStruct構造体でパラメーター化した場合は、 MyStructインスタンスのベクトルをinsert_many()メソッドのパラメーターとして渡します。
Tip
単一ドキュメントを挿入するには、代わりに insert_one() メソッドを使用することを検討してください。このメソッドを使用する実行可能なコード例については、 ドキュメントの挿入 の使用例を参照してください。
insert_many() メソッドは、挿入されたドキュメントの _id 値を参照する InsertManyResult 型を返します。
コレクションにドキュメントを挿入する方法の詳細については、「ドキュメントの挿入 」ガイドを参照してください。
例
この例では、 sample_restaurantsデータベースの restaurantsコレクションに複数のドキュメントを挿入します。 この例では、ドキュメントのベクトルを insert_many() メソッドに渡すことで、name と cuisineフィールド値を持つドキュメントを挿入します。
これらのドキュメントは、Document 型またはカスタムデータ型のインスタンスとして挿入できます。 コレクションのデータを表すデータ型を指定するには、強調表示された行に対して次のアクションを実行します。
- コレクションドキュメントをBSONドキュメントとしてアクセスして挿入するには、 - <T>型パラメータを- <Document>に置き換え、- <struct or doc>プレースホルダーを- insert_docsに置き換えます。
- Restaurant構造体のインスタンスとしてコレクションドキュメントにアクセスして挿入するには、- <T>型パラメータを- <Restaurant>に置き換え、- <struct or doc>プレースホルダーを- insert_structsに置き換えます。- Restaurant構造体は、コードファイルの上部で定義されています。
AsynchronousSynchronous各実行時に対応するコードを表示するには、 タブまたは タブを選択します。
use mongodb::{      bson::{doc, Document},     Client,     Collection  }; use serde::{ Deserialize, Serialize }; struct Restaurant {     name: String,     cuisine: String, } async fn main() -> mongodb::error::Result<()> {     let uri = "<connection string>";     let client = Client::with_uri_str(uri).await?;     // Replace <T> with the <Document> or <Restaurant> type parameter     let my_coll: Collection<T> = client         .database("sample_restaurants")         .collection("restaurants");     let insert_docs = vec! [         doc! {              "name": "While in Kathmandu",             "cuisine": "Nepalese",         },         doc! {              "name": "Cafe Himalaya",             "cuisine": "Nepalese",         }     ];     let insert_structs = vec! [         Restaurant {             name: "While in Kathmandu".to_string(),             cuisine: "Nepalese".to_string(),         },         Restaurant {             name: "Cafe Himalaya".to_string(),             cuisine: "Nepalese".to_string(),         }     ];          // Replace <structs or docs> with the insert_structs or insert_docs variable     let insert_many_result = my_coll.insert_many(<structs or docs>).await?;     println!("Inserted documents with _ids:");     for (_key, value) in &insert_many_result.inserted_ids {         println!("{}", value);     }              Ok(()) } 
Inserted documents with _ids: ObjectId("...") ObjectId("...") 
use mongodb::{     bson::{doc, Document},     sync::{Client, Collection} }; use serde::{ Deserialize, Serialize }; struct Restaurant {     name: String,     cuisine: String, } fn main() -> mongodb::error::Result<()> {     let uri = "<connection string>";     let client = Client::with_uri_str(uri)?;     // Replace <T> with the <Document> or <Restaurant> type parameter     let my_coll: Collection<T> = client         .database("sample_restaurants")         .collection("restaurants");     let insert_docs = vec! [         doc! {              "name": "While in Kathmandu",             "cuisine": "Nepalese",         },         doc! {              "name": "Cafe Himalaya",             "cuisine": "Nepalese",         }     ];     let insert_structs = vec! [         Restaurant {             name: "While in Kathmandu".to_string(),             cuisine: "Nepalese".to_string(),         },         Restaurant {             name: "Cafe Himalaya".to_string(),             cuisine: "Nepalese".to_string(),         }     ];          // Replace <structs or docs> with the insert_structs or insert_docs variable     let insert_many_result = my_coll.insert_many(<structs or docs>).run()?;     println!("Inserted documents with _ids:");     for (_key, value) in &insert_many_result.inserted_ids {         println!("{}", value);     }     Ok(()) } 
Inserted documents with _ids: ObjectId("...") ObjectId("...")