Overview
En esta guía, puedes aprender a usar el controlador de Rust para realizar operaciones compuestas.
Las operaciones compuestas combinan la funcionalidad de las operaciones de lectura y escritura en una sola atomic acción. Si realizas una operación de lectura y una operación de guardar en secuencia, alguien podría cambiar tu documento objetivo entre operaciones, lo que podría llevar a resultados inesperados. Cuando realizas una operación compuesta, MongoDB previene los cambios intermedios de datos colocando un bloqueo de escritura en el documento que estás modificando hasta que la operación se complete.
Puede realizar las siguientes operaciones compuestas con el controlador:
Buscar y eliminar un documento
Buscar y actualizar un documento
Buscar y reemplazar un documento
Esta guía incluye las siguientes secciones:
Datos de muestra para ejemplos presenta los datos de muestra que se utilizan en los ejemplos de operaciones combinadas
Encontrar y borrar un documento describe cómo encontrar y borrar un documento en una sola operación
Buscar y actualizar un documento describe cómo buscar y actualizar un documento en una sola operación
Buscar y reemplazar un documento describe cómo buscar y reemplazar un documento en una sola operación
Información adicional proporciona enlaces a recursos y documentación de la API para los tipos y métodos mencionados en esta guía
Tip
Para aprender cómo realizar operaciones atómicas de lectura y escritura en más de un documento a la vez, consulta el Transactions guide.
Datos de muestra para ejemplos
Los ejemplos de esta guía utilizan los siguientes documentos de muestra. Cada documento representa a un estudiante y contiene información sobre su edad y la escuela a la que asisten:
{ "name": "Alex Johnson", "age": 8, "school": "Lakeside Elementary" }, { "name": "Samara Khan", "age": 11, "school": "Rolling Hills Middle School" }, { "name": "Ben Joseph", "age": 16, "school": "Aurora High School" }, { "name": "Deanna Porowski", "age": 10, "school": "Lakeside Elementary" }
Buscar y eliminar un documento
La find_one_and_delete() El método encuentra y borra el primer documento que coincide con el filtro de query especificado. Si un documento coincide con los criterios del filtro, el método devuelve un tipo Some. Si ningún documento tiene coincidencias, devuelve un tipo None.
Nota
Si desea realizar otras operaciones entre buscar y eliminar un documento, puede llamar al método find_one() seguido del método delete_one().
Modificar el comportamiento de búsqueda y borrar
Opcionalmente, puedes modificar el comportamiento del método find_one_and_delete() encadenando métodos del generador de opciones a find_one_and_delete(). Estos métodos de compilación establecen los campos de estructura de FindOneAndDeleteOptions.
La siguiente tabla describe las opciones disponibles en FindOneAndDeleteOptions:
Opción | Descripción |
|---|---|
| The maximum amount of time in milliseconds that the query can
run. Type: Duration |
| The projection to use when returning results. Type: DocumentDefault: None |
| The sorting order to use when returning results. By default, the driver
returns documents in their natural order, or as they appear in
the database. To learn more, see natural order
in the Server manual glossary. Type: DocumentDefault: None |
| The write concern for the operation. If you don't set this
option, the operation inherits the write concern set for
the collection. To learn more about write concerns, see
Write Concern in the
Server manual. Type: WriteConcern |
| The collation to use when sorting results. To learn more about collations,
see the Collations guide. Type: CollationDefault: None |
| The index to use for the operation. To learn more about
indexes, see Indexes in the Server
manual. This option is available only when connecting to
MongoDB Server versions 4.4 and later. Type: HintDefault: None |
| A map of parameters and values. You can access these parameters
as variables in aggregation expressions. This option is available
only when connecting to MongoDB Server versions 5.0 and later. Type: Document |
| An arbitrary Bson value tied to the operation to trace
it through the database profiler, currentOp, and
logs. This option is available only when connecting to
MongoDB Server versions 4.4 and later.Type: BsonDefault: None |
Nota
Opciones de configuración
Puedes configurar los campos de FindOneAndDeleteOptions encadenando métodos del generador de opciones directamente a la llamada del método find_one_and_delete(). Si está utilizando una versión anterior del controlador, debe construir una instancia de FindOneAndDeleteOptions encadenando métodos del generador de opciones al método builder(). Luego, pasa tu instancia de opciones como un parámetro a find_one_and_delete().
El siguiente código muestra cómo establecer el campo comment encadenando el método comment() al método find_one_and_delete():
let res = my_coll.find_one_and_delete(filter) .comment(bson!("hello")) .await?;
Buscar y borrar ejemplo
El siguiente ejemplo utiliza el método find_one_and_delete() para hacer coincidir y eliminar el primer documento donde el valor del campo age sea menor o igual a 10:
let filter = doc! { "age": doc! { "$lte": 10 } }; let res = my_coll.find_one_and_delete(filter).await?; println!("Deleted document:\n{:?}", res);
Deleted document: Some(Document({"_id": ObjectId("..."), "name": String("Deanna Porowski"), "age": Int32(10), "school": String("Lakeside Elementary")}))
Buscar y actualizar un documento
El método find_one_and_update() encuentra y actualiza el primer documento que coincida con el filtro de query especificado. La operación actualiza el documento según las especificaciones que se brindan en un documento de actualización. Si un documento coincide con los criterios del filtro, el método devuelve un tipo Some. Si ningún documento coincide, devuelve un tipo None.
Nota
Si desea realizar otras operaciones entre encontrar y actualizar un documento, puede llamar al método find_one() seguido del método update_one().
Modificar el comportamiento de búsqueda y actualización
Opcionalmente, puedes modificar el comportamiento del método find_one_and_update() encadenando métodos del generador de opciones a find_one_and_update(). Estos métodos de compilación establecen los campos de estructura de FindOneAndUpdateOptions.
La siguiente tabla describe las opciones disponibles en FindOneAndUpdateOptions:
Opción | Descripción |
|---|---|
| The set of filters specifying the array elements to which the
update applies. Type: Vec<Document> |
| If true, allows the driver to perform a write that violates
document-level validation. To learn more about validation, see
Schema Validation in the Server manual.Type: boolDefault: false |
| The maximum amount of time in milliseconds that the query can
run. Type: Duration |
| The projection to use when returning results. Type: DocumentDefault: None |
| If Before, the operation returns the document before the
update. If After, the operation returns the updated document.Type: ReturnDocumentDefault: ReturnDocument::Before |
| The sorting order to use when returning results. By default, the driver
returns documents in their natural order, or as they appear in
the database. To learn more, see natural order
in the Server manual glossary. Type: DocumentDefault: None |
| If true, the operation inserts a document if no documents match
the query filter. Type: boolDefault: false |
| The write concern for the operation. If you don't set this
option, the operation inherits the write concern set for
the collection. To learn more about write concerns, see
Write Concern in the
Server manual. Type: WriteConcern |
| The collation to use when sorting results. To learn more about collations,
see the Collations guide. Type: CollationDefault: None |
| The index to use for the operation. To learn more about
indexes, see Indexes in the Server
manual. This option is available only when connecting to
MongoDB Server versions 4.4 and later. Type: HintDefault: None |
| A map of parameters and values. You can access these parameters
as variables in aggregation expressions. This option is available
only when connecting to MongoDB Server versions 5.0 and later. Type: Document |
| An arbitrary Bson value tied to the operation to trace
it through the database profiler, currentOp, and
logs. This option is available only when connecting to
MongoDB Server versions 4.4 and later.Type: BsonDefault: None |
El siguiente código muestra cómo establecer el campo comment encadenando el método comment() al método find_one_and_update():
let res = my_coll.find_one_and_update(filter, update) .comment(bson!("hello")) .await?;
Ejemplo de búsqueda y actualización
Este ejemplo muestra cómo realizar las siguientes acciones:
Llama al método
find_one_and_update()Pasa un filtro de query a
find_one_and_update()que coincida con un documento donde el valor deschoolsea"Aurora High School"Pase un documento de actualización a
find_one_and_update()que establezca el camposchoolen"Durango High School"e incremente el campoageen1Encadena el método
return_document()afind_one_and_update()para devolver el documento coincidente después de la actualización
let filter = doc! { "school": "Aurora High School" }; let update = doc! { "$set": doc! { "school": "Durango High School" }, "$inc": doc! { "age": 1 } }; let res = my_coll.find_one_and_update(filter, update) .return_document(ReturnDocument::After) .await?; println!("Updated document:\n{:?}", res);
Updated document: Some(Document({"_id": ObjectId("..."), "name": String("Ben Joseph"), "age": Int32(17), "school": String("Durango High School")}))
Localizar e substituir um documento
El método find_one_and_replace() busca y reemplaza el primer documento que coincida con el filtro de consulta especificado. La operación reemplaza todos los campos del documento, excepto el campo _id, con los campos y valores que proporcione. Si un documento cumple los criterios del filtro, el método devuelve un tipo Some. Si ningún documento coincide, devuelve un tipo None.
Nota
Si desea realizar otras operaciones entre buscar y reemplazar un documento, puede llamar al método find_one() seguido del método replace_one().
Modificar el comportamiento de Buscar y reemplazar
Opcionalmente, puedes modificar el comportamiento del método find_one_and_replace() encadenando métodos del generador de opciones a find_one_and_replace(). Estos métodos de compilación establecen los campos de estructura de FindOneAndReplaceOptions.
La siguiente tabla describe las opciones disponibles en FindOneAndReplaceOptions:
Opción | Descripción |
|---|---|
| If true, allows the driver to perform a write that violates
document-level validation. To learn more about validation, see
Schema Validation in the Server manual.Type: boolDefault: false |
| The maximum amount of time in milliseconds that the query can
run. Type: Duration |
| The projection to use when returning results. Type: DocumentDefault: None |
| If Before, the operation returns the document before the
update. If After, the operation returns the updated document.Type: ReturnDocumentDefault: ReturnDocument::Before |
| The sorting order to use when returning results. By default, the driver
returns documents in their natural order, or as they appear in
the database. To learn more, see natural order
in the Server manual glossary. Type: DocumentDefault: None |
| If true, the operation inserts a document if no documents match
the query filter. Type: boolDefault: false |
| The write concern for the operation. If you don't set this
option, the operation inherits the write concern set for
the collection. To learn more about write concerns, see
Write Concern in the
Server manual. Type: WriteConcern |
| The collation to use when sorting results. To learn more about collations,
see the Collations guide. Type: CollationDefault: None |
| The index to use for the operation. To learn more about
indexes, see Indexes in the Server
manual. This option is available only when connecting to
MongoDB Server versions 4.4 and later. Type: HintDefault: None |
| A map of parameters and values. You can access these parameters
as variables in aggregation expressions. This option is available
only when connecting to MongoDB Server versions 5.0 and later. Type: Document |
| An arbitrary Bson value tied to the operation to trace
it through the database profiler, currentOp, and
logs. This option is available only when connecting to
MongoDB Server versions 4.4 and later.Type: BsonDefault: None |
El siguiente código muestra cómo establecer el campo comment encadenando el método comment() al método find_one_and_replace():
let res = my_coll.find_one_and_replace(filter, replacement) .comment(bson!("hello")) .await?;
Ejemplo de buscar y reemplazar
Este ejemplo realiza las siguientes acciones:
Llama al método
find_one_and_replace()Pasa un filtro de query a
find_one_and_replace()que coincide con un documento donde el valor denameincluye la cadena"Johnson"Pasa un documento de reemplazo a
find_one_and_replace()que describe a un nuevo estudianteEncadena el método
return_document()afind_one_and_replace()para devolver el documento después de la sustitución.Encadena el método
projection()a los camposfind_one_and_replace()``to project only the ``nameyschoolen la salida
let filter = doc! { "name": doc! { "$regex": "Johnson" } }; let replacement = doc! { "name": "Toby Fletcher", "age": 14, "school": "Durango High School" }; let res = my_coll.find_one_and_replace(filter, replacement) .return_document(ReturnDocument::After) .projection(doc! { "name": 1, "school": 1, "_id": 0 }) .await?; println!("Document after replacement:\n{:?}", res);
Document after replacement: Some(Document({"name": String("Toby Fletcher"), "school": String("Durango High School")}))
Información Adicional
Para obtener más información sobre las operaciones de esta guía, consulte la siguiente documentación:
Documentación de la API
Para obtener más información sobre los métodos y tipos mencionados en esta guía, vea la siguiente documentación de la API: