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>) -> ValueAccessResult<f64>
pub fn get_f64(&self, key: impl AsRef<str>) -> ValueAccessResult<f64>
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>
) -> ValueAccessResult<&mut f64>
pub fn get_f64_mut( &mut self, key: impl AsRef<str> ) -> ValueAccessResult<&mut f64>
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>
) -> ValueAccessResult<&Decimal128>
pub fn get_decimal128( &self, key: impl AsRef<str> ) -> ValueAccessResult<&Decimal128>
Get a reference to a Decimal128 value for key, if it exists.
sourcepub fn get_decimal128_mut(
&mut self,
key: impl AsRef<str>
) -> ValueAccessResult<&mut Decimal128>
pub fn get_decimal128_mut( &mut self, key: impl AsRef<str> ) -> ValueAccessResult<&mut Decimal128>
Get a mutable reference to a Decimal128 value for key, if it exists.
sourcepub fn get_str(&self, key: impl AsRef<str>) -> ValueAccessResult<&str>
pub fn get_str(&self, key: impl AsRef<str>) -> ValueAccessResult<&str>
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>
) -> ValueAccessResult<&mut str>
pub fn get_str_mut( &mut self, key: impl AsRef<str> ) -> ValueAccessResult<&mut str>
Get a mutable string slice this key if it exists and has the correct type.
sourcepub fn get_array(&self, key: impl AsRef<str>) -> ValueAccessResult<&Array>
pub fn get_array(&self, key: impl AsRef<str>) -> ValueAccessResult<&Array>
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>
) -> ValueAccessResult<&mut Array>
pub fn get_array_mut( &mut self, key: impl AsRef<str> ) -> ValueAccessResult<&mut Array>
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>) -> ValueAccessResult<&Document>
pub fn get_document(&self, key: impl AsRef<str>) -> ValueAccessResult<&Document>
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>
) -> ValueAccessResult<&mut Document>
pub fn get_document_mut( &mut self, key: impl AsRef<str> ) -> ValueAccessResult<&mut Document>
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>) -> ValueAccessResult<bool>
pub fn get_bool(&self, key: impl AsRef<str>) -> ValueAccessResult<bool>
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>
) -> ValueAccessResult<&mut bool>
pub fn get_bool_mut( &mut self, key: impl AsRef<str> ) -> ValueAccessResult<&mut bool>
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>) -> ValueAccessResult<i32>
pub fn get_i32(&self, key: impl AsRef<str>) -> ValueAccessResult<i32>
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>
) -> ValueAccessResult<&mut i32>
pub fn get_i32_mut( &mut self, key: impl AsRef<str> ) -> ValueAccessResult<&mut i32>
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>) -> ValueAccessResult<i64>
pub fn get_i64(&self, key: impl AsRef<str>) -> ValueAccessResult<i64>
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>
) -> ValueAccessResult<&mut i64>
pub fn get_i64_mut( &mut self, key: impl AsRef<str> ) -> ValueAccessResult<&mut i64>
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>
) -> ValueAccessResult<Timestamp>
pub fn get_timestamp( &self, key: impl AsRef<str> ) -> ValueAccessResult<Timestamp>
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>
) -> ValueAccessResult<&mut Timestamp>
pub fn get_timestamp_mut( &mut self, key: impl AsRef<str> ) -> ValueAccessResult<&mut Timestamp>
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>
) -> ValueAccessResult<&Vec<u8>>
pub fn get_binary_generic( &self, key: impl AsRef<str> ) -> ValueAccessResult<&Vec<u8>>
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>
) -> ValueAccessResult<&mut Vec<u8>>
pub fn get_binary_generic_mut( &mut self, key: impl AsRef<str> ) -> ValueAccessResult<&mut Vec<u8>>
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>) -> ValueAccessResult<ObjectId>
pub fn get_object_id(&self, key: impl AsRef<str>) -> ValueAccessResult<ObjectId>
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>
) -> ValueAccessResult<&mut ObjectId>
pub fn get_object_id_mut( &mut self, key: impl AsRef<str> ) -> ValueAccessResult<&mut ObjectId>
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>) -> ValueAccessResult<&DateTime>
pub fn get_datetime(&self, key: impl AsRef<str>) -> ValueAccessResult<&DateTime>
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>
) -> ValueAccessResult<&mut DateTime>
pub fn get_datetime_mut( &mut self, key: impl AsRef<str> ) -> ValueAccessResult<&mut DateTime>
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: Into<String>, BT: Into<Bson>>(
&mut self,
key: KT,
val: BT
) -> Option<Bson>
pub fn insert<KT: Into<String>, BT: Into<Bson>>( &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: Write>(&self, writer: W) -> Result<()>
pub fn to_writer<W: Write>(&self, writer: W) -> Result<()>
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: Read>(reader: R) -> Result<Document>
pub fn from_reader<R: Read>(reader: R) -> Result<Document>
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: Read>(reader: R) -> Result<Document>
pub fn from_reader_utf8_lossy<R: Read>(reader: R) -> Result<Document>
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<Self, D::Error>where
D: Deserializer<'de>,
fn deserialize<D>(deserializer: D) -> Result<Self, D::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: IntoIterator<Item = (String, Bson)>>(&mut self, iter: T)
fn extend<T: IntoIterator<Item = (String, Bson)>>(&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<'a> IntoIterator for &'a Document
impl<'a> IntoIterator for &'a Document
source§impl IntoIterator for Document
impl IntoIterator for Document
source§impl PartialEq for Document
impl PartialEq for Document
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
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 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> 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> 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) -> Rwhere
Self: Borrow<B>,
B: 'a + ?Sized,
R: 'a,
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> Rwhere Self: Borrow<B>, B: 'a + ?Sized, R: 'a,
source§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R
) -> Rwhere
Self: BorrowMut<B>,
B: 'a + ?Sized,
R: 'a,
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R ) -> Rwhere Self: BorrowMut<B>, B: 'a + ?Sized, R: 'a,
source§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> Rwhere
Self: AsRef<U>,
U: 'a + ?Sized,
R: 'a,
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> Rwhere Self: AsRef<U>, U: 'a + ?Sized, R: 'a,
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) -> Rwhere
Self: AsMut<U>,
U: 'a + ?Sized,
R: 'a,
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> Rwhere Self: AsMut<U>, U: 'a + ?Sized, R: 'a,
self
, then passes self.as_mut()
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)) -> Selfwhere
Self: Borrow<B>,
B: ?Sized,
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Selfwhere Self: Borrow<B>, B: ?Sized,
Borrow<B>
of a value. Read moresource§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Selfwhere
Self: BorrowMut<B>,
B: ?Sized,
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Selfwhere Self: BorrowMut<B>, B: ?Sized,
BorrowMut<B>
of a value. Read moresource§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Selfwhere
Self: AsRef<R>,
R: ?Sized,
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Selfwhere Self: AsRef<R>, R: ?Sized,
AsRef<R>
view of a value. Read moresource§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Selfwhere
Self: AsMut<R>,
R: ?Sized,
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Selfwhere Self: AsMut<R>, R: ?Sized,
AsMut<R>
view of a value. Read moresource§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Selfwhere
Self: Deref<Target = T>,
T: ?Sized,
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Selfwhere Self: Deref<Target = T>, T: ?Sized,
Deref::Target
of a value. Read moresource§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Selfwhere
Self: DerefMut<Target = T> + Deref,
T: ?Sized,
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Selfwhere Self: DerefMut<Target = T> + Deref, T: ?Sized,
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)) -> Selfwhere
Self: Borrow<B>,
B: ?Sized,
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Selfwhere Self: Borrow<B>, B: ?Sized,
.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)) -> Selfwhere
Self: BorrowMut<B>,
B: ?Sized,
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Selfwhere Self: BorrowMut<B>, B: ?Sized,
.tap_borrow_mut()
only in debug builds, and is erased in release
builds.source§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Selfwhere
Self: AsRef<R>,
R: ?Sized,
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Selfwhere Self: AsRef<R>, R: ?Sized,
.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)) -> Selfwhere
Self: AsMut<R>,
R: ?Sized,
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Selfwhere Self: AsMut<R>, R: ?Sized,
.tap_ref_mut()
only in debug builds, and is erased in release
builds.