22 #include <bsoncxx/builder/basic/array.hpp> 23 #include <bsoncxx/builder/basic/document.hpp> 24 #include <bsoncxx/builder/basic/kvp.hpp> 25 #include <bsoncxx/builder/concatenate.hpp> 26 #include <bsoncxx/document/view_or_value.hpp> 27 #include <bsoncxx/oid.hpp> 28 #include <bsoncxx/stdx/optional.hpp> 29 #include <bsoncxx/string/view_or_value.hpp> 30 #include <mongocxx/bulk_write.hpp> 31 #include <mongocxx/change_stream.hpp> 32 #include <mongocxx/client_session.hpp> 33 #include <mongocxx/cursor.hpp> 34 #include <mongocxx/index_view.hpp> 35 #include <mongocxx/model/insert_one.hpp> 36 #include <mongocxx/options/aggregate.hpp> 37 #include <mongocxx/options/bulk_write.hpp> 38 #include <mongocxx/options/change_stream.hpp> 39 #include <mongocxx/options/count.hpp> 40 #include <mongocxx/options/delete.hpp> 41 #include <mongocxx/options/distinct.hpp> 42 #include <mongocxx/options/estimated_document_count.hpp> 43 #include <mongocxx/options/find.hpp> 44 #include <mongocxx/options/find_one_and_delete.hpp> 45 #include <mongocxx/options/find_one_and_replace.hpp> 46 #include <mongocxx/options/find_one_and_update.hpp> 47 #include <mongocxx/options/index.hpp> 48 #include <mongocxx/options/index_view.hpp> 49 #include <mongocxx/options/insert.hpp> 50 #include <mongocxx/options/replace.hpp> 51 #include <mongocxx/options/update.hpp> 52 #include <mongocxx/pipeline.hpp> 53 #include <mongocxx/read_concern.hpp> 54 #include <mongocxx/read_preference.hpp> 55 #include <mongocxx/result/bulk_write.hpp> 56 #include <mongocxx/result/delete.hpp> 57 #include <mongocxx/result/insert_many.hpp> 58 #include <mongocxx/result/insert_one.hpp> 59 #include <mongocxx/result/replace_one.hpp> 60 #include <mongocxx/result/update.hpp> 61 #include <mongocxx/write_concern.hpp> 63 #include <mongocxx/config/prelude.hpp> 66 MONGOCXX_INLINE_NAMESPACE_BEGIN
124 explicit operator bool()
const noexcept;
172 const pipeline& pipeline,
204 class bulk_write create_bulk_write(const client_session& session,
232 MONGOCXX_INLINE stdx::optional<result::bulk_write> write(
257 MONGOCXX_INLINE stdx::optional<result::bulk_write> write(
258 const client_session& session,
288 template <
typename container_type>
289 MONGOCXX_INLINE stdx::optional<result::bulk_write>
bulk_write(
315 template <
typename container_type>
316 MONGOCXX_INLINE stdx::optional<result::bulk_write> bulk_write(
317 const client_session& session,
318 const container_type& writes,
348 template <
typename write_model_iterator_type>
349 MONGOCXX_INLINE stdx::optional<result::bulk_write> bulk_write(
350 write_model_iterator_type begin,
351 write_model_iterator_type end,
378 template <
typename write_model_iterator_type>
379 MONGOCXX_INLINE stdx::optional<result::bulk_write> bulk_write(
380 const client_session& session,
381 write_model_iterator_type begin,
382 write_model_iterator_type end,
476 MONGOCXX_DEPRECATED std::int64_t count(
const client_session& session,
480 std::int64_t count_deprecated(
const client_session& session,
518 std::int64_t count_documents(
const client_session& session,
537 std::int64_t estimated_document_count(
591 const client_session& session,
618 stdx::optional<result::delete_result> delete_many(
640 stdx::optional<result::delete_result> delete_many(
641 const client_session& session,
667 stdx::optional<result::delete_result> delete_one(
689 stdx::optional<result::delete_result> delete_one(
690 const client_session& session,
738 cursor distinct(
const client_session& session,
765 void drop(
const bsoncxx::stdx::optional<mongocxx::write_concern>&
write_concern = {});
785 void drop(
const client_session& session,
786 const bsoncxx::stdx::optional<mongocxx::write_concern>&
write_concern = {});
833 cursor find(
const client_session& session,
853 stdx::optional<bsoncxx::document::value> find_one(
872 stdx::optional<bsoncxx::document::value> find_one(
873 const client_session& session,
900 stdx::optional<bsoncxx::document::value> find_one_and_delete(
923 stdx::optional<bsoncxx::document::value> find_one_and_delete(
924 const client_session& session,
954 stdx::optional<bsoncxx::document::value> find_one_and_replace(
981 stdx::optional<bsoncxx::document::value> find_one_and_replace(
982 const client_session& session,
1013 stdx::optional<bsoncxx::document::value> find_one_and_update(
1040 stdx::optional<bsoncxx::document::value> find_one_and_update(
1041 const client_session& session,
1084 stdx::optional<result::insert_one> insert_one(
const client_session& session,
1116 template <
typename container_type>
1117 MONGOCXX_INLINE stdx::optional<result::insert_many> insert_many(
1141 template <
typename container_type>
1142 MONGOCXX_INLINE stdx::optional<result::insert_many> insert_many(
1143 const client_session& session,
1144 const container_type& container,
1172 template <
typename document_view_iterator_type>
1173 MONGOCXX_INLINE stdx::optional<result::insert_many> insert_many(
1174 document_view_iterator_type begin,
1175 document_view_iterator_type end,
1199 template <
typename document_view_iterator_type>
1200 MONGOCXX_INLINE stdx::optional<result::insert_many> insert_many(
1201 const client_session& session,
1202 document_view_iterator_type begin,
1203 document_view_iterator_type end,
1220 cursor list_indexes()
const;
1234 cursor list_indexes(
const client_session& session)
const;
1246 stdx::string_view name()
const;
1268 bool drop_target_before_rename =
false,
1269 const bsoncxx::stdx::optional<write_concern>&
write_concern = {});
1292 void rename(
const client_session& session,
1294 bool drop_target_before_rename =
false,
1295 const bsoncxx::stdx::optional<write_concern>&
write_concern = {});
1320 class read_concern read_concern() const;
1340 class read_preference read_preference() const;
1364 stdx::optional<result::replace_one> replace_one(
1391 stdx::optional<result::replace_one> replace_one(
1392 const client_session& session,
1421 template <
typename T,
1422 typename std::enable_if<std::is_same<T, options::update>::value,
int>::type = 0>
1427 return replace_one_deprecated(filter, replacement, options);
1430 stdx::optional<result::replace_one> replace_one_deprecated(
1461 template <
typename T,
1462 typename std::enable_if<std::is_same<T, options::update>::value,
int>::type = 0>
1464 const client_session& session,
1468 return replace_one_deprecated(session, filter, replacement, options);
1471 stdx::optional<result::replace_one> replace_one_deprecated(
1472 const client_session& session,
1529 stdx::optional<result::update> update_many(
const client_session& session,
1586 stdx::optional<result::update> update_one(
const client_session& session,
1609 class write_concern write_concern() const;
1678 const pipeline& pipe,
1686 friend class bulk_write;
1692 MONGOCXX_PRIVATE collection(
const database& database,
void* collection);
1694 MONGOCXX_PRIVATE
cursor _aggregate(
const client_session* session,
1695 const pipeline& pipeline,
1698 MONGOCXX_PRIVATE std::int64_t _count(
const client_session* session,
1702 MONGOCXX_PRIVATE std::int64_t _count_documents(
const client_session* session,
1707 const client_session* session,
1712 MONGOCXX_PRIVATE stdx::optional<result::delete_result> _delete_many(
1713 const client_session* session,
1717 MONGOCXX_PRIVATE stdx::optional<result::delete_result> _delete_one(
1718 const client_session* session,
1722 MONGOCXX_PRIVATE
cursor _distinct(
const client_session* session,
1727 MONGOCXX_PRIVATE
void _drop(
1728 const client_session* session,
1729 const bsoncxx::stdx::optional<mongocxx::write_concern>& write_concern);
1731 MONGOCXX_PRIVATE
cursor _find(
const client_session* session,
1735 MONGOCXX_PRIVATE stdx::optional<bsoncxx::document::value> _find_one(
1736 const client_session* session,
1740 MONGOCXX_PRIVATE stdx::optional<bsoncxx::document::value> _find_one_and_delete(
1741 const client_session* session,
1745 MONGOCXX_PRIVATE stdx::optional<bsoncxx::document::value> _find_one_and_replace(
1746 const client_session* session,
1751 MONGOCXX_PRIVATE stdx::optional<bsoncxx::document::value> _find_one_and_update(
1752 const client_session* session,
1757 MONGOCXX_PRIVATE stdx::optional<result::insert_one> _insert_one(
1758 const client_session* session,
1762 MONGOCXX_PRIVATE
void _rename(
1763 const client_session* session,
1765 bool drop_target_before_rename,
1766 const bsoncxx::stdx::optional<class write_concern>& write_concern);
1768 MONGOCXX_PRIVATE stdx::optional<result::replace_one> _replace_one(
1769 const client_session* session,
1773 MONGOCXX_PRIVATE stdx::optional<result::replace_one> _replace_one(
1774 const client_session* session,
1779 MONGOCXX_PRIVATE stdx::optional<result::replace_one> _replace_one(
1780 const client_session* session,
1785 MONGOCXX_PRIVATE stdx::optional<result::update> _update_one(
1786 const client_session* session,
1791 MONGOCXX_PRIVATE stdx::optional<result::update> _update_many(
1792 const client_session* session,
1797 MONGOCXX_PRIVATE
change_stream _watch(
const client_session* session,
1798 const pipeline& pipe,
1802 class bulk_write _init_insert_many(const options::insert& options,
1803 const client_session* session);
1805 void _insert_many_doc_handler(class bulk_write& writes,
1806 bsoncxx::builder::basic::array& inserted_ids,
1807 bsoncxx::document::view doc) const;
1809 stdx::optional<result::insert_many> _exec_insert_many(
1810 class bulk_write& writes, bsoncxx::builder::basic::array& inserted_ids);
1812 template <typename document_view_iterator_type>
1813 MONGOCXX_PRIVATE stdx::optional<result::insert_many> _insert_many(
1814 const client_session* session,
1815 document_view_iterator_type begin,
1816 document_view_iterator_type end,
1817 const options::insert& options);
1819 class MONGOCXX_PRIVATE impl;
1821 MONGOCXX_PRIVATE impl& _get_impl();
1822 MONGOCXX_PRIVATE const impl& _get_impl() const;
1824 std::unique_ptr<impl> _impl;
1828 const model::write& write, const options::bulk_write& options) {
1834 return create_bulk_write(session, options).
append(write).
execute();
1837 template <
typename container_type>
1838 MONGOCXX_INLINE stdx::optional<result::bulk_write> collection::bulk_write(
1840 return bulk_write(requests.begin(), requests.end(), options);
1843 template <
typename container_type>
1844 MONGOCXX_INLINE stdx::optional<result::bulk_write> collection::bulk_write(
1845 const client_session& session,
1846 const container_type& requests,
1848 return bulk_write(session, requests.begin(), requests.end(), options);
1851 template <
typename write_model_iterator_type>
1852 MONGOCXX_INLINE stdx::optional<result::bulk_write> collection::bulk_write(
1853 write_model_iterator_type begin,
1854 write_model_iterator_type end,
1856 auto writes = create_bulk_write(options);
1857 std::for_each(begin, end, [&](
const model::write& current) { writes.append(current); });
1858 return writes.execute();
1861 template <
typename write_model_iterator_type>
1862 MONGOCXX_INLINE stdx::optional<result::bulk_write> collection::bulk_write(
1863 const client_session& session,
1864 write_model_iterator_type begin,
1865 write_model_iterator_type end,
1867 auto writes = create_bulk_write(session, options);
1868 std::for_each(begin, end, [&](
const model::write& current) { writes.append(current); });
1869 return writes.execute();
1872 template <
typename container_type>
1875 return insert_many(container.begin(), container.end(), options);
1878 template <
typename container_type>
1880 const client_session& session,
1881 const container_type& container,
1883 return insert_many(session, container.begin(), container.end(), options);
1886 template <
typename document_view_iterator_type>
1887 MONGOCXX_INLINE stdx::optional<result::insert_many> collection::_insert_many(
1889 const client_session* session,
1890 document_view_iterator_type begin,
1891 document_view_iterator_type end,
1894 auto writes = _init_insert_many(options, session);
1896 _insert_many_doc_handler(writes, inserted_ids, doc);
1898 return _exec_insert_many(writes, inserted_ids);
1901 template <
typename document_view_iterator_type>
1903 document_view_iterator_type begin,
1904 document_view_iterator_type end,
1906 return _insert_many(
nullptr, begin, end, options);
1909 template <
typename document_view_iterator_type>
1911 const client_session& session,
1912 document_view_iterator_type begin,
1913 document_view_iterator_type end,
1915 return _insert_many(&session, begin, end, options);
1918 MONGOCXX_INLINE_NAMESPACE_END
1921 #include <mongocxx/config/postlude.hpp> Top level namespace for the MongoDB C++ driver.
Definition: bulk_write.hpp:24
Class representing the optional arguments to a MongoDB replace operation.
Definition: replace.hpp:32
A read-only BSON document that owns its underlying buffer.
Definition: value.hpp:33
Class representing the optional arguments to a MongoDB query.
Definition: find.hpp:36
A read-only, non-owning view of a BSON document.
Definition: view.hpp:33
Class representing a pointer to the result set of a query on a MongoDB server.
Definition: cursor.hpp:36
Class representing a MongoDB update operation that replaces a single document.
Definition: replace_one.hpp:30
Class representing the optional arguments to a MongoDB distinct command.
Definition: distinct.hpp:34
Class representing the optional arguments to a MongoDB bulk write.
Definition: bulk_write.hpp:29
Class representing the optional arguments to a MongoDB insert operation.
Definition: insert.hpp:31
Use a session for a sequence of operations, optionally with causal consistency.
Definition: client_session.hpp:38
Class representing a MongoDB database.
Definition: database.hpp:44
stdx::optional< result::bulk_write > write(const model::write &write, const options::bulk_write &options=options::bulk_write())
Sends a write to the server as a bulk write operation.
Definition: collection.hpp:1827
Class representing the optional arguments to a MongoDB update operation.
Definition: update.hpp:32
MONGOCXX_DEPRECATED stdx::optional< result::replace_one > replace_one(const client_session &session, bsoncxx::document::view_or_value filter, bsoncxx::document::view_or_value replacement, const T &options)
Replaces a single document matching the provided filter in this collection.
Definition: collection.hpp:1463
Class representing a batch of write operations that can be sent to the server as a group...
Definition: bulk_write.hpp:43
Definition: change_stream.hpp:31
Class representing the optional arguments to a MongoDB delete operation.
Definition: delete.hpp:30
A traditional builder-style interface for constructing a BSON array.
Definition: array.hpp:35
Class representing a MongoDB aggregation pipeline.
Definition: pipeline.hpp:37
bulk_write & append(const model::write &operation)
Appends a single write to the bulk write operation.
Class representing a preference for how the driver routes read operations to members of a replica set...
Definition: read_preference.hpp:62
Class representing the optional arguments to a MongoDB aggregation operation.
Definition: aggregate.hpp:36
Definition: change_stream.hpp:35
Class representing a view-or-value variant type for strings.
Definition: view_or_value.hpp:36
Models a single write operation within a mongocxx::bulk_write.
Definition: write.hpp:37
stdx::optional< result::bulk_write > execute() const
Executes a bulk write.
Definition: index_view.hpp:32
Class representing optional arguments to IndexView operations.
Definition: index_view.hpp:31
A class to represent the read concern.
Definition: read_concern.hpp:53
Class representing the optional arguments to a MongoDB find_and_modify replace operation.
Definition: find_one_and_replace.hpp:35
stdx::optional< result::insert_many > insert_many(const container_type &container, const options::insert &options=options::insert())
Inserts multiple documents into the collection.
Definition: collection.hpp:1873
Class representing the optional arguments to a MongoDB find_and_modify delete operation.
Definition: find_one_and_delete.hpp:33
MONGOCXX_DEPRECATED stdx::optional< result::replace_one > replace_one(bsoncxx::document::view_or_value filter, bsoncxx::document::view_or_value replacement, const T &options)
Replaces a single document matching the provided filter in this collection.
Definition: collection.hpp:1423
Class representing the server-side requirement for reporting the success of a write operation...
Definition: write_concern.hpp:56
Class representing the optional arguments to mongocxx::collection::estimated_document_count.
Definition: estimated_document_count.hpp:32
Class representing the optional arguments to mongocxx::collection::count_documents.
Definition: count.hpp:36
Class representing the optional arguments to a MongoDB find_and_modify update operation.
Definition: find_one_and_update.hpp:36
Class representing server side document groupings within a MongoDB database.
Definition: collection.hpp:85