pub struct Document { /* private fields */ }Expand description
A BSON document represented as an associative HashMap with insertion ordering.
Implementations§
Source§impl Document
 
impl Document
Sourcepub fn iter_mut(&mut self) -> IterMut<'_> ⓘ
 
pub fn iter_mut(&mut self) -> IterMut<'_> ⓘ
Gets an iterator over pairs of keys and mutable values.
Sourcepub fn get(&self, key: impl AsRef<str>) -> Option<&Bson>
 
pub fn get(&self, key: impl AsRef<str>) -> Option<&Bson>
Returns a reference to the Bson corresponding to the key.
Sourcepub fn get_mut(&mut self, key: impl AsRef<str>) -> Option<&mut Bson>
 
pub fn get_mut(&mut self, key: impl AsRef<str>) -> Option<&mut Bson>
Gets a mutable reference to the Bson corresponding to the key
Sourcepub fn get_f64(&self, key: impl AsRef<str>) -> Result<f64, ValueAccessError>
 
pub fn get_f64(&self, key: impl AsRef<str>) -> Result<f64, ValueAccessError>
Get a floating point value for this key if it exists and has the correct type.
Sourcepub fn get_f64_mut(
    &mut self,
    key: impl AsRef<str>,
) -> Result<&mut f64, ValueAccessError>
 
pub fn get_f64_mut( &mut self, key: impl AsRef<str>, ) -> Result<&mut f64, ValueAccessError>
Get a mutable reference to a floating point value for this key if it exists and has the correct type.
Sourcepub fn get_decimal128(
    &self,
    key: impl AsRef<str>,
) -> Result<&Decimal128, ValueAccessError>
 
pub fn get_decimal128( &self, key: impl AsRef<str>, ) -> Result<&Decimal128, ValueAccessError>
Get a reference to a Decimal128 value for key, if it exists.
Sourcepub fn get_decimal128_mut(
    &mut self,
    key: impl AsRef<str>,
) -> Result<&mut Decimal128, ValueAccessError>
 
pub fn get_decimal128_mut( &mut self, key: impl AsRef<str>, ) -> Result<&mut Decimal128, ValueAccessError>
Get a mutable reference to a Decimal128 value for key, if it exists.
Sourcepub fn get_str(&self, key: impl AsRef<str>) -> Result<&str, ValueAccessError>
 
pub fn get_str(&self, key: impl AsRef<str>) -> Result<&str, ValueAccessError>
Get a string slice this key if it exists and has the correct type.
Sourcepub fn get_str_mut(
    &mut self,
    key: impl AsRef<str>,
) -> Result<&mut str, ValueAccessError>
 
pub fn get_str_mut( &mut self, key: impl AsRef<str>, ) -> Result<&mut str, ValueAccessError>
Get a mutable string slice this key if it exists and has the correct type.
Sourcepub fn get_array(
    &self,
    key: impl AsRef<str>,
) -> Result<&Vec<Bson>, ValueAccessError>
 
pub fn get_array( &self, key: impl AsRef<str>, ) -> Result<&Vec<Bson>, ValueAccessError>
Get a reference to an array for this key if it exists and has the correct type.
Sourcepub fn get_array_mut(
    &mut self,
    key: impl AsRef<str>,
) -> Result<&mut Vec<Bson>, ValueAccessError>
 
pub fn get_array_mut( &mut self, key: impl AsRef<str>, ) -> Result<&mut Vec<Bson>, ValueAccessError>
Get a mutable reference to an array for this key if it exists and has the correct type.
Sourcepub fn get_document(
    &self,
    key: impl AsRef<str>,
) -> Result<&Document, ValueAccessError>
 
pub fn get_document( &self, key: impl AsRef<str>, ) -> Result<&Document, ValueAccessError>
Get a reference to a document for this key if it exists and has the correct type.
Sourcepub fn get_document_mut(
    &mut self,
    key: impl AsRef<str>,
) -> Result<&mut Document, ValueAccessError>
 
pub fn get_document_mut( &mut self, key: impl AsRef<str>, ) -> Result<&mut Document, ValueAccessError>
Get a mutable reference to a document for this key if it exists and has the correct type.
Sourcepub fn get_bool(&self, key: impl AsRef<str>) -> Result<bool, ValueAccessError>
 
pub fn get_bool(&self, key: impl AsRef<str>) -> Result<bool, ValueAccessError>
Get a bool value for this key if it exists and has the correct type.
Sourcepub fn get_bool_mut(
    &mut self,
    key: impl AsRef<str>,
) -> Result<&mut bool, ValueAccessError>
 
pub fn get_bool_mut( &mut self, key: impl AsRef<str>, ) -> Result<&mut bool, ValueAccessError>
Get a mutable reference to a bool value for this key if it exists and has the correct type.
Sourcepub fn get_i32(&self, key: impl AsRef<str>) -> Result<i32, ValueAccessError>
 
pub fn get_i32(&self, key: impl AsRef<str>) -> Result<i32, ValueAccessError>
Get an i32 value for this key if it exists and has the correct type.
Sourcepub fn get_i32_mut(
    &mut self,
    key: impl AsRef<str>,
) -> Result<&mut i32, ValueAccessError>
 
pub fn get_i32_mut( &mut self, key: impl AsRef<str>, ) -> Result<&mut i32, ValueAccessError>
Get a mutable reference to an i32 value for this key if it exists and has the correct type.
Sourcepub fn get_i64(&self, key: impl AsRef<str>) -> Result<i64, ValueAccessError>
 
pub fn get_i64(&self, key: impl AsRef<str>) -> Result<i64, ValueAccessError>
Get an i64 value for this key if it exists and has the correct type.
Sourcepub fn get_i64_mut(
    &mut self,
    key: impl AsRef<str>,
) -> Result<&mut i64, ValueAccessError>
 
pub fn get_i64_mut( &mut self, key: impl AsRef<str>, ) -> Result<&mut i64, ValueAccessError>
Get a mutable reference to an i64 value for this key if it exists and has the correct type.
Sourcepub fn get_timestamp(
    &self,
    key: impl AsRef<str>,
) -> Result<Timestamp, ValueAccessError>
 
pub fn get_timestamp( &self, key: impl AsRef<str>, ) -> Result<Timestamp, ValueAccessError>
Get a time stamp value for this key if it exists and has the correct type.
Sourcepub fn get_timestamp_mut(
    &mut self,
    key: impl AsRef<str>,
) -> Result<&mut Timestamp, ValueAccessError>
 
pub fn get_timestamp_mut( &mut self, key: impl AsRef<str>, ) -> Result<&mut Timestamp, ValueAccessError>
Get a mutable reference to a time stamp value for this key if it exists and has the correct type.
Sourcepub fn get_binary_generic(
    &self,
    key: impl AsRef<str>,
) -> Result<&Vec<u8>, ValueAccessError>
 
pub fn get_binary_generic( &self, key: impl AsRef<str>, ) -> Result<&Vec<u8>, ValueAccessError>
Get a reference to a generic binary value for this key if it exists and has the correct type.
Sourcepub fn get_binary_generic_mut(
    &mut self,
    key: impl AsRef<str>,
) -> Result<&mut Vec<u8>, ValueAccessError>
 
pub fn get_binary_generic_mut( &mut self, key: impl AsRef<str>, ) -> Result<&mut Vec<u8>, ValueAccessError>
Get a mutable reference generic binary value for this key if it exists and has the correct type.
Sourcepub fn get_object_id(
    &self,
    key: impl AsRef<str>,
) -> Result<ObjectId, ValueAccessError>
 
pub fn get_object_id( &self, key: impl AsRef<str>, ) -> Result<ObjectId, ValueAccessError>
Get an object id value for this key if it exists and has the correct type.
Sourcepub fn get_object_id_mut(
    &mut self,
    key: impl AsRef<str>,
) -> Result<&mut ObjectId, ValueAccessError>
 
pub fn get_object_id_mut( &mut self, key: impl AsRef<str>, ) -> Result<&mut ObjectId, ValueAccessError>
Get a mutable reference to an object id value for this key if it exists and has the correct type.
Sourcepub fn get_datetime(
    &self,
    key: impl AsRef<str>,
) -> Result<&DateTime, ValueAccessError>
 
pub fn get_datetime( &self, key: impl AsRef<str>, ) -> Result<&DateTime, ValueAccessError>
Get a reference to a UTC datetime value for this key if it exists and has the correct type.
Sourcepub fn get_datetime_mut(
    &mut self,
    key: impl AsRef<str>,
) -> Result<&mut DateTime, ValueAccessError>
 
pub fn get_datetime_mut( &mut self, key: impl AsRef<str>, ) -> Result<&mut DateTime, ValueAccessError>
Get a mutable reference to a UTC datetime value for this key if it exists and has the correct type.
Sourcepub fn contains_key(&self, key: impl AsRef<str>) -> bool
 
pub fn contains_key(&self, key: impl AsRef<str>) -> bool
Returns true if the map contains a value for the specified key.
Sourcepub fn insert<KT, BT>(&mut self, key: KT, val: BT) -> Option<Bson>
 
pub fn insert<KT, BT>(&mut self, key: KT, val: BT) -> Option<Bson>
Sets the value of the entry with the OccupiedEntry’s key, and returns the entry’s old value. Accepts any type that can be converted into Bson.
Sourcepub fn remove(&mut self, key: impl AsRef<str>) -> Option<Bson>
 
pub fn remove(&mut self, key: impl AsRef<str>) -> Option<Bson>
Takes the value of the entry out of the document, and returns it. Computes in O(n) time (average).
pub fn entry(&mut self, k: String) -> Entry<'_>
Sourcepub fn to_writer<W>(&self, writer: W) -> Result<(), Error>where
    W: Write,
 
pub fn to_writer<W>(&self, writer: W) -> Result<(), Error>where
    W: Write,
Attempts to serialize the Document into a byte stream.
While the method signature indicates an owned writer must be passed in, a mutable reference
may also be passed in due to blanket implementations of Write provided in the standard
library.
use bson::doc;
let mut v: Vec<u8> = Vec::new();
let doc = doc! { "x" : 1 };
doc.to_writer(&mut v)?;Sourcepub fn from_reader<R>(reader: R) -> Result<Document, Error>where
    R: Read,
 
pub fn from_reader<R>(reader: R) -> Result<Document, Error>where
    R: Read,
Attempts to deserialize a Document from a byte stream.
While the method signature indicates an owned reader must be passed in, a mutable reference
may also be passed in due to blanket implementations of Read provided in the standard
library.
use bson::{doc, Document};
use std::io::Cursor;
let mut v: Vec<u8> = Vec::new();
let doc = doc! { "x" : 1 };
doc.to_writer(&mut v)?;
// read from mutable reference
let mut reader = Cursor::new(v.clone());
let doc1 = Document::from_reader(&mut reader)?;
// read from owned value
let doc2 = Document::from_reader(Cursor::new(v))?;
assert_eq!(doc, doc1);
assert_eq!(doc, doc2);Sourcepub fn from_reader_utf8_lossy<R>(reader: R) -> Result<Document, Error>where
    R: Read,
 👎Deprecated: use bson::serde_helpers::Utf8LossyDeserialization
pub fn from_reader_utf8_lossy<R>(reader: R) -> Result<Document, Error>where
    R: Read,
Attempt to deserialize a Document that may contain invalid UTF-8 strings from a byte
stream.
This is mainly useful when reading raw BSON returned from a MongoDB server, which
in rare cases can contain invalidly truncated strings (https://jira.mongodb.org/browse/SERVER-24007).
For most use cases, Document::from_reader can be used instead.
Trait Implementations§
Source§impl<'de> Deserialize<'de> for Document
 
impl<'de> Deserialize<'de> for Document
Source§fn deserialize<D>(
    deserializer: D,
) -> Result<Document, <D as Deserializer<'de>>::Error>where
    D: Deserializer<'de>,
 
fn deserialize<D>(
    deserializer: D,
) -> Result<Document, <D as Deserializer<'de>>::Error>where
    D: Deserializer<'de>,
Deserialize this value given this Deserializer.
Source§impl Extend<(String, Bson)> for Document
 
impl Extend<(String, Bson)> for Document
Source§fn extend<T>(&mut self, iter: T)
 
fn extend<T>(&mut self, iter: T)
Source§fn extend_one(&mut self, item: A)
 
fn extend_one(&mut self, item: A)
extend_one)Source§fn extend_reserve(&mut self, additional: usize)
 
fn extend_reserve(&mut self, additional: usize)
extend_one)Source§impl From<Document> for UpdateModifications
 
impl From<Document> for UpdateModifications
Source§fn from(item: Document) -> UpdateModifications
 
fn from(item: Document) -> UpdateModifications
Source§impl<'a> IntoIterator for &'a Document
 
impl<'a> IntoIterator for &'a Document
Source§impl IntoIterator for Document
 
impl IntoIterator for Document
Source§impl Serialize for Document
 
impl Serialize for Document
Source§fn serialize<S>(
    &self,
    serializer: S,
) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error>where
    S: Serializer,
 
fn serialize<S>(
    &self,
    serializer: S,
) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error>where
    S: Serializer,
Source§impl TryFrom<&Document> for RawDocumentBuf
 
impl TryFrom<&Document> for RawDocumentBuf
Source§impl TryFrom<&RawDocument> for Document
 
impl TryFrom<&RawDocument> for Document
Source§impl TryFrom<Map<String, Value>> for Document
This converts from the input JSON as if it were MongoDB Extended JSON v2.
 
impl TryFrom<Map<String, Value>> for Document
This converts from the input JSON as if it were MongoDB Extended JSON v2.
Source§impl TryFrom<RawDocumentBuf> for Document
 
impl TryFrom<RawDocumentBuf> for Document
impl StructuralPartialEq for Document
Auto Trait Implementations§
impl Freeze for Document
impl RefUnwindSafe for Document
impl Send for Document
impl Sync for Document
impl Unpin for Document
impl UnwindSafe for Document
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
 
impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
 
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
    T: Clone,
 
impl<T> CloneToUninit for Twhere
    T: Clone,
Source§impl<T> FmtForward for T
 
impl<T> FmtForward for T
Source§fn fmt_binary(self) -> FmtBinary<Self>where
    Self: Binary,
 
fn fmt_binary(self) -> FmtBinary<Self>where
    Self: Binary,
self to use its Binary implementation when Debug-formatted.Source§fn fmt_display(self) -> FmtDisplay<Self>where
    Self: Display,
 
fn fmt_display(self) -> FmtDisplay<Self>where
    Self: Display,
self to use its Display implementation when
Debug-formatted.Source§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
    Self: LowerExp,
 
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
    Self: LowerExp,
self to use its LowerExp implementation when
Debug-formatted.Source§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
    Self: LowerHex,
 
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
    Self: LowerHex,
self to use its LowerHex implementation when
Debug-formatted.Source§fn fmt_octal(self) -> FmtOctal<Self>where
    Self: Octal,
 
fn fmt_octal(self) -> FmtOctal<Self>where
    Self: Octal,
self to use its Octal implementation when Debug-formatted.Source§fn fmt_pointer(self) -> FmtPointer<Self>where
    Self: Pointer,
 
fn fmt_pointer(self) -> FmtPointer<Self>where
    Self: Pointer,
self to use its Pointer implementation when
Debug-formatted.Source§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
    Self: UpperExp,
 
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
    Self: UpperExp,
self to use its UpperExp implementation when
Debug-formatted.Source§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
    Self: UpperHex,
 
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
    Self: UpperHex,
self to use its UpperHex implementation when
Debug-formatted.Source§impl<T> Instrument for T
 
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
 
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
 
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> Pipe for Twhere
    T: ?Sized,
 
impl<T> Pipe for Twhere
    T: ?Sized,
Source§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
    Self: Sized,
 
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
    Self: Sized,
Source§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
    R: 'a,
 
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
    R: 'a,
self and passes that borrow into the pipe function. Read moreSource§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
    R: 'a,
 
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
    R: 'a,
self and passes that borrow into the pipe function. Read moreSource§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
 
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
Source§fn pipe_borrow_mut<'a, B, R>(
    &'a mut self,
    func: impl FnOnce(&'a mut B) -> R,
) -> R
 
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
Source§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
 
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self, then passes self.as_ref() into the pipe function.Source§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
 
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self, then passes self.as_mut() into the pipe
function.Source§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
 
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self, then passes self.deref() into the pipe function.Source§impl<T> Tap for T
 
impl<T> Tap for T
Source§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
 
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B> of a value. Read moreSource§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
 
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B> of a value. Read moreSource§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
 
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R> view of a value. Read moreSource§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
 
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R> view of a value. Read moreSource§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
 
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target of a value. Read moreSource§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
 
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target of a value. Read moreSource§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
 
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap() only in debug builds, and is erased in release builds.Source§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
 
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut() only in debug builds, and is erased in release
builds.Source§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
 
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow() only in debug builds, and is erased in release
builds.Source§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
 
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut() only in debug builds, and is erased in release
builds.Source§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
 
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref() only in debug builds, and is erased in release
builds.Source§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
 
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut() only in debug builds, and is erased in release
builds.Source§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
 
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref() only in debug builds, and is erased in release
builds.