Puede recuperar un solo documento de una colección llamando a la find_one() método sobre un Collection instancia.
Pasa un filtro de query al método find_one() para devolver un documento en la colección que coincida con el filtro. Si varios documentos coinciden con el filtro de query, este método devuelve el primer documento coincidente según su orden natural en la base de datos o según el orden de clasificación especificado en una instancia de FindOneOptions.
El método find_one() devuelve un tipo Option<T>, donde T es el tipo con el que parametrizaste tu instancia de Collection.
Para obtener más información sobre la recuperación de documentos, consulte el Retrieve Data guide.
Ejemplo
Este ejemplo recupera un documento que coincide con un filtro de query de la colección restaurants en la base de datos sample_restaurants. El método find_one() devuelve el primer documento en el que el valor del campo name es "Tompkins Square Bagels".
Puede modelar el documento recuperado como un tipo Document o un tipo de datos personalizado. Para especificar qué tipo de datos representa los datos de la colección, reemplace el parámetro de tipo <T> en la línea resaltada por uno de los siguientes valores:
<Document>:Recupera e imprime documentos de colección como documentos BSON<Restaurant>: Recupera e imprime documentos de la colección como instancias de la estructuraRestaurant, definida al inicio del código
Selecciona el Asynchronous o la pestaña Synchronous para ver el código correspondiente para cada entorno de ejecución:
use mongodb::{ bson::doc, Client, Collection }; use serde::{ Deserialize, Serialize }; struct Restaurant { name: String, cuisine: String, } async fn main() -> mongodb::error::Result<()> { let uri = "<connection string>"; let client = Client::with_uri_str(uri).await?; // Replace <T> with the <Document> or <Restaurant> type parameter let my_coll: Collection<T> = client .database("sample_restaurants") .collection("restaurants"); let result = my_coll.find_one( doc! { "name": "Tompkins Square Bagels" } ).await?; println!("{:#?}", result); Ok(()) }
use mongodb::{ bson::doc, sync::{Client, Collection} }; use serde::{ Deserialize, Serialize }; struct Restaurant { name: String, cuisine: String, } fn main() -> mongodb::error::Result<()> { let uri = "<connection string>"; let client = Client::with_uri_str(uri)?; // Replace <T> with the <Document> or <Restaurant> type parameter let my_coll: Collection<T> = client .database("sample_restaurants") .collection("restaurants"); let result = my_coll.find_one( doc! { "name": "Tompkins Square Bagels" } ).run()?; println!("{:#?}", result); Ok(()) }
Salida
Selecciona la pestaña BSON Document Result o Restaurant Struct Result para ver la salida de código correspondiente según el parámetro de tipo de tu colección:
Some( Document({ "_id": ObjectId( "...", ), ... "name": String( "Tompkins Square Bagels", ), ... }), )
Some( Restaurant { name: "Tompkins Square Bagels", cuisine: "American", }, )