Docs Menu
Docs Home
/ / /
C++ ドライバー

MongoDB へのデータの書込み (write)

項目一覧

  • Overview
  • サンプル アプリケーション
  • 1 つを挿入
  • 複数挿入
  • 更新 1
  • 複数更新
  • deleteOne
  • 複数削除
  • 一括書き込み (write)

このページでは、 MongoDBにデータを書き込むための一般的なC++ドライバー メソッドを示すコピー可能なコード例があります。

Tip

このページに記載されているメソッドの詳細については、各セクションに提供されているリンクを参照してください。

このページの例を使用するには、コード例をサンプルアプリケーションまたは 独自のアプリケーションにコピーします。 <connection string>などのすべてのプレースホルダーを、 MongoDBデプロイに関連する値に置き換えてください。

次のサンプルアプリケーションを使用して、このページのコード例をテストできます。 サンプル アプリケーションを使用するには、次の手順を実行します。

  1. プロジェクトが C++ ドライバーをインポートできるロケーションにC++ドライバーがインストールされていることを確認してください。

  2. 次のコードをコピーし、プロジェクト内の新しい.cppファイルに貼り付けます。

  3. このページからコード例をコピーし、ファイルのハイライトされたセクション内に貼り付けます。

1#include <iostream>
2
3#include <bsoncxx/builder/basic/document.hpp>
4#include <bsoncxx/json.hpp>
5#include <mongocxx/client.hpp>
6#include <mongocxx/exception/exception.hpp>
7#include <mongocxx/instance.hpp>
8#include <mongocxx/uri.hpp>
9
10using bsoncxx::builder::basic::kvp;
11using bsoncxx::builder::basic::make_document;
12
13int main() {
14 try {
15 mongocxx::instance instance;
16
17 mongocxx::uri uri("<connection string>");
18 mongocxx::client client(uri);
19
20 auto database = client["<database name>"];
21 auto collection = database["<collection name>"];
22
23 // Start example code here
24
25 // End example code here
26
27 } catch (const mongocxx::exception& e) {
28 std::cout << "An exception occurred: " << e.what() << "\n";
29 return EXIT_FAILURE;
30 }
31
32 return EXIT_SUCCESS;
33}

次のコードは、コレクションに単一のドキュメントを挿入する方法を示しています。

auto result = collection.insert_one(make_document(kvp("<field name>", "<value>")));

insert_one()メソッドの詳細については、 ドキュメントの挿入ガイドを参照してください。

次のコードは、コレクションに複数のドキュメントを挿入する方法を示しています。

std::vector<bsoncxx::document::value> documents;
documents.push_back(make_document(kvp("<field name>", "<value>")));
documents.push_back(make_document(kvp("<field name>", "<value>")));
auto result = collection.insert_many(documents);

insert_many()メソッドについて詳しくは、ドキュメントの挿入ガイドをご覧ください。

次のコードは、フィールドを作成または編集して、コレクション内の 1 つのドキュメントを更新する方法を示しています。

auto query_filter = make_document(kvp("<field to match>", "<value to match>"));
auto update_doc = make_document(kvp("$set", make_document(kvp("<field name>", "<value>"))));
auto result = collection.update_one(query_filter.view(), update_doc.view());

update_one()メソッドについて詳しくは、ドキュメントの更新ガイドを参照してください。

次のコードは、フィールドを作成または編集して、コレクション内の複数のドキュメントを更新する方法を示しています。

auto query_filter = make_document(kvp("<field to match>", "<value to match>"));
auto update_doc = make_document(kvp("$set", make_document(kvp("<field name>", "<value>"))));
auto result = collection.update_many(query_filter.view(), update_doc.view());

update_many()メソッドについて詳しくは、ドキュメントの更新ガイドを参照してください。

次のコードは、コレクション内の 1 つのドキュメントを削除する方法を示しています。

auto result = collection.delete_one(make_document(kvp("<field name>", "<value>")));

delete_one()メソッドの詳細については、ドキュメントの削除のガイドを参照してください。

次のコードは、コレクション内の複数のドキュメントを削除する方法を示しています。

auto result = collection.delete_many(make_document(kvp("<field name>", "<value>")));

delete_many()メソッドの詳細については、ドキュメントの削除のガイドを参照してください。

次のコードは、1 つの一括操作で複数の書き込み操作を実行する方法を示しています。

auto bulk = collection.create_bulk_write();
auto insert_doc = make_document(kvp("<field name>", "<value>"));
auto update_filter = make_document(kvp("<field name>", "<value>"));
auto update_doc = make_document(kvp("$set", make_document(kvp("<field name>", "<value>"))));
auto delete_filter = make_document(kvp("<field name>", "<value>"));
mongocxx::model::insert_one insert_op{insert_doc.view()};
mongocxx::model::update_many update_op{update_filter.view(), update_doc.view()};
mongocxx::model::delete_one delete_op{delete_filter.view()};
bulk.append(insert_op);
bulk.append(update_op);
bulk.append(delete_op);
auto result = bulk.execute();

create_bulk_write()メソッドの詳細については、一括書込みのガイドを参照してください。

戻る

データの変更を監視