MongoDB C++ Driver mongocxx-3.11.0
Loading...
Searching...
No Matches
update_one.hpp
Go to the documentation of this file.
1// Copyright 2009-present MongoDB, Inc.
2//
3// Licensed under the Apache License, Version 2.0 (the "License");
4// you may not use this file except in compliance with the License.
5// You may obtain a copy of the License at
6//
7// http://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS,
11// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12// See the License for the specific language governing permissions and
13// limitations under the License.
14
15#pragma once
16
18
22
23#include <mongocxx/hint.hpp>
24#include <mongocxx/pipeline.hpp>
25#include <mongocxx/stdx.hpp>
26
28
29namespace mongocxx {
30namespace v_noabi {
31namespace model {
32
37 //
38 // Utility class supporting the convenience of {} meaning an empty bsoncxx::v_noabi::document.
39 //
40 // Users may not use this class directly.
41 //
42 // In places where driver methods take this class as a parameter, passing {} will
43 // translate to a default-constructed bsoncxx::v_noabi::document::view_or_value,
44 // regardless of other overloads taking other default-constructible types
45 // for that parameter. This class avoids compiler ambiguity with such overloads.
46 //
47 // See update_one() for an example of such overloads.
48 //
49 class _empty_doc_tag {};
50
51 public:
61 update_one(bsoncxx::v_noabi::document::view_or_value filter,
62 bsoncxx::v_noabi::document::view_or_value update);
63
73 update_one(bsoncxx::v_noabi::document::view_or_value filter, const pipeline& update);
74
84 update_one(bsoncxx::v_noabi::document::view_or_value filter,
85 std::initializer_list<_empty_doc_tag> update);
86
92 MONGOCXX_ABI_EXPORT_CDECL(const bsoncxx::v_noabi::document::view_or_value&) filter() const;
93
99 MONGOCXX_ABI_EXPORT_CDECL(const bsoncxx::v_noabi::document::view_or_value&) update() const;
100
111 collation(bsoncxx::v_noabi::document::view_or_value collation);
112
122 MONGOCXX_ABI_EXPORT_CDECL(const stdx::optional<bsoncxx::v_noabi::document::view_or_value>&)
123 collation() const;
124
139
145 MONGOCXX_ABI_EXPORT_CDECL(const stdx::optional<mongocxx::v_noabi::hint>&) hint() const;
146
161
167 MONGOCXX_ABI_EXPORT_CDECL(const stdx::optional<bool>&) upsert() const;
168
179 array_filters(bsoncxx::v_noabi::array::view_or_value array_filters);
180
190 MONGOCXX_ABI_EXPORT_CDECL(const stdx::optional<bsoncxx::v_noabi::array::view_or_value>&)
192
193 private:
194 bsoncxx::v_noabi::document::view_or_value _filter;
195 bsoncxx::v_noabi::document::view_or_value _update;
196
197 stdx::optional<bsoncxx::v_noabi::document::view_or_value> _collation;
198 stdx::optional<bsoncxx::v_noabi::array::view_or_value> _array_filters;
199 stdx::optional<bool> _upsert;
200 stdx::optional<mongocxx::v_noabi::hint> _hint;
201};
202
203} // namespace model
204} // namespace v_noabi
205} // namespace mongocxx
206
207#include <mongocxx/config/postlude.hpp>
208
Provides bsoncxx::v_noabi::array::view_or_value.
Class representing a hint to be passed to a database operation.
Definition hint.hpp:37
Class representing a MongoDB update operation that modifies a single document.
Definition update_one.hpp:36
const stdx::optional< bsoncxx::v_noabi::document::view_or_value > & collation() const
Gets the collation option for this update operation.
const bsoncxx::v_noabi::document::view_or_value & filter() const
Gets the filter.
const bsoncxx::v_noabi::document::view_or_value & update() const
Gets the update document.
const stdx::optional< bsoncxx::v_noabi::array::view_or_value > & array_filters() const
Get array filters for this operation.
const stdx::optional< bool > & upsert() const
Gets the current value of the upsert option.
Class representing a MongoDB aggregation pipeline.
Definition pipeline.hpp:39
Provides bsoncxx::v_noabi::document::view_or_value.
#define MONGOCXX_ABI_EXPORT_CDECL(...)
Equivalent to MONGOCXX_ABI_EXPORT with MONGOCXX_ABI_CDECL.
Definition fwd.hpp:222
Provides mongocxx::v_noabi::hint.
The mongocxx macro guard prelude header.
The top-level namespace within which all bsoncxx library entities are declared.
The top-level namespace within which all mongocxx library entities are declared.
The top-level namespace reserved for the C++ standard library.
Provides std::optional-related polyfills for library API usage.
Provides mongocxx::v_noabi::pipeline.
Redeclares bsoncxx::v_noabi::stdx in mongocxx::v_noabi::stdx for internal use.
Declares mongocxx::v_noabi::model::update_one.