文档菜单
文档首页
/ / /
C++ 驱动程序

将数据写入 MongoDB

本页内容

  • 概述
  • 示例应用程序
  • 插入单个文档
  • 插入多个文档
  • 更新单个文档
  • 更新多个文档
  • 替换单个文档
  • 删除单个文档
  • 删除多个文档
  • 批量写入

在本页中,您可以查看可复制的代码示例,展示用于将数据写入MongoDB的常见C++驱动程序方法。

提示

要了解本页面上显示的任何方法,请参阅每个部分中提供的链接。

要使用本页上的示例,请将代码示例复制到示例应用程序或您自己的应用程序中。请确保用您MongoDB部署的相关值替换所有占位符,例如<连接字符串>

您可以使用以下示例应用程序测试本页上的代码示例。要使用示例应用程序,请执行以下步骤

  1. 确保您已将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() 方法的信息,请参阅插入文档指南。

以下代码演示如何通过创建或编辑字段来更新集合中的一个文档

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() 方法的知识,请参阅更新文档指南。

以下代码展示了如何替换集合中的一个文档

auto query_filter = make_document(kvp("<field to match>", "<value to match>"));
auto replace_doc = make_document(make_document(kvp("<field name>", "<value>")));
auto result = collection.replace_one(query_filter.view(), replace_doc.view());

要了解更多关于 replace_one() 方法的知识,请参阅替换文档指南。

以下代码展示了如何删除集合中的一个文档

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() 方法的知识,请参阅删除文档指南。

以下代码展示了如何在单个批量操作中执行多个写入操作

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() 方法的知识,请参阅批量写入指南。

返回

监控变更