Join us at MongoDB.local London on 7 May to unlock new possibilities for your data. Use WEB50 to save 50%.
Register now >
Docs Menu
Docs Home
/ /

Operaciones compuestas

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:

  • Encuentra y elimina un documento

  • Buscar y actualizar un documento

  • Buscar y reemplazar un documento

Esta guía incluye las siguientes secciones:

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.

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" }

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 deseas realizar otras operaciones entre la búsqueda y la eliminación de un documento, puedes llamar al método find_one() seguido del método delete_one().

Opcionalmente, se puede modificar el comportamiento del método find_one_and_delete() pasando una instancia FineOneAndDeleteOptions como parámetro. Para utilizar los valores por defecto para cada configuración, especifica el valor None para el parámetro de opciones.

La siguiente tabla describe las opciones disponibles en FineOneAndDeleteOptions:

Opción
Descripción

max_time

The maximum amount of time in milliseconds that the query can run.

Type: Duration

projection

The projection to use when returning results.

Type: Document
Default: None

sort

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: Document
Default: None

write_concern

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

collation

The collation to use when sorting results. To learn more about collations, see the Collations guide.

Type: Collation
Default: None

hint

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: Hint
Default: None

let_vars

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

comment

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: Bson
Default: None

El controlador de Rust implementa el patrón de diseño del Builder para la creación de una instancia de FindOneAndDeleteOptions. Puedes usar el método builder() del tipo para construir una instancia de opciones encadenando funciones de construcción de opciones una a la vez.

El siguiente código ilustra cómo construir una instancia de FindOneAndDeleteOptions y pasarla al método find_one_and_delete():

let opts = FindOneAndDeleteOptions::builder().comment(bson!("hello")).build();
let res = my_coll.find_one_and_delete(filter, opts).await?;

El siguiente ejemplo utiliza el método find_one_and_delete() para buscar y borrar el primer documento donde el valor del campo age es menor o igual a 10:

let filter = doc! { "age": doc! { "$lte": 10 } };
let res = my_coll.find_one_and_delete(filter, None).await?;
println!("Deleted document:\n{:?}", res);
Deleted document:
Some(Document({"_id": ObjectId("..."),
"name": String("Deanna Porowski"), "age": Int32(10), "school":
String("Lakeside Elementary")}))

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().

Opcionalmente, se puede modificar el comportamiento del método find_one_and_update() pasando una instancia FindOneAndUpdateOptions como parámetro. Para utilizar los valores por defecto para cada configuración, especifica el valor None para el parámetro de opciones.

La siguiente tabla describe las opciones disponibles en FineOneAndDeleteOptions:

Opción
Descripción

array_filters

The set of filters specifying the array elements to which the update applies.

Type: Vec<Document>

bypass_document_validation

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: bool
Default: false

max_time

The maximum amount of time in milliseconds that the query can run.

Type: Duration

projection

The projection to use when returning results.

Type: Document
Default: None

return_document

If Before, the operation returns the document before the update. If After, the operation returns the updated document.

Type: ReturnDocument
Default: ReturnDocument::Before

sort

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: Document
Default: None

upsert

If true, the operation inserts a document if no documents match the query filter.

Type: bool
Default: false

write_concern

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

collation

The collation to use when sorting results. To learn more about collations, see the Collations guide.

Type: Collation
Default: None

hint

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: Hint
Default: None

let_vars

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

comment

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: Bson
Default: None

El controlador de Rust implementa el patrón de diseño Builder para la creación de una instancia de FindOneAndUpdateOptions . Puedes usar el método builder() del tipo para construir una instancia de opciones encadenando los métodos del generador de opciones uno a uno.

El siguiente código ilustra cómo construir una instancia de FindOneAndUpdateOptions y pasarla al método find_one_and_update():

let opts = FindOneAndUpdateOptions::builder().comment(bson!("hello")).build();
let res = my_coll.find_one_and_update(filter, update, opts).await?;

Este ejemplo muestra cómo llamar al método find_one_and_update() con los siguientes parámetros:

  • Un filtro de query que coincide con un documento donde el valor de school es "Aurora High School"

  • Un documento de actualización que establece el campo school en "Durango High School" y aumenta el campo age en 1

  • Una instancia de FindOneAndUpdateOptions que devuelve el documento 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 opts = FindOneAndUpdateOptions::builder()
.return_document(Some(ReturnDocument::After))
.build();
let res = my_coll.find_one_and_update(filter, update, opts).await?;
println!("Updated document:\n{:?}", res);
Updated document:
Some(Document({"_id": ObjectId("..."),
"name": String("Ben Joseph"), "age": Int32(17), "school":
String("Durango High School")}))

El método find_one_and_replace() encuentra y reemplaza el primer documento que coincide con el filtro de query especificado. La operación reemplaza todos los campos del documento excepto el campo _id con los campos y valores que usted proporcione. 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 deseas realizar otras operaciones entre encontrar y reemplazar un documento, puedes llamar al método find_one() seguido del método replace_one().

Opcionalmente, se puede modificar el comportamiento del método find_one_and_replace() pasando una instancia FindOneAndReplaceOptions como parámetro. Para utilizar los valores por defecto para cada configuración, especifica el valor None para el parámetro de opciones.

La siguiente tabla describe las opciones disponibles en FindOneAndReplaceOptions:

Opción
Descripción

bypass_document_validation

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: bool
Default: false

max_time

The maximum amount of time in milliseconds that the query can run.

Type: Duration

projection

The projection to use when returning results.

Type: Document
Default: None

return_document

If Before, the operation returns the document before the update. If After, the operation returns the updated document.

Type: ReturnDocument
Default: ReturnDocument::Before

sort

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: Document
Default: None

upsert

If true, the operation inserts a document if no documents match the query filter.

Type: bool
Default: false

write_concern

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

collation

The collation to use when sorting results. To learn more about collations, see the Collations guide.

Type: Collation
Default: None

hint

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: Hint
Default: None

let_vars

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

comment

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: Bson
Default: None

El controlador de Rust implementa el patrón de diseño del Builder para la creación de una instancia de FindOneAndReplaceOptions. Puedes usar el método builder() del tipo para construir una instancia de opciones encadenando funciones de construcción de opciones una a la vez.

El siguiente código ilustra cómo construir una instancia de FindOneAndReplaceOptions y pasarla al método find_one_and_replace():

let opts = FindOneAndReplaceOptions::builder().comment(bson!("hello")).build();
let res = my_coll.find_one_and_replace(filter, replacement, opts).await?;

Este ejemplo muestra cómo llamar al método find_one_and_replace() con los siguientes parámetros:

  • Un filtro de consulta que coincide con un documento en el que el valor de name incluye la string "Johnson"

  • Un documento de reemplazo que describe a un estudiante nuevo

  • Una instancia de FindOneAndReplaceOptions que devuelve el documento tras el reemplazo y proyecta únicamente los campos name y school en la salida

let filter = doc! { "name": doc! { "$regex": "Johnson" } };
let replacement =
doc! { "name": "Toby Fletcher",
"age": 14,
"school": "Durango High School" };
let opts = FindOneAndReplaceOptions::builder()
.return_document(Some(ReturnDocument::After))
.projection(doc! { "name": 1, "school": 1, "_id": 0 })
.build();
let res = my_coll.find_one_and_replace(filter, replacement, opts).await?;
println!("Document after replacement:\n{:?}", res);
Document after replacement:
Some(Document({"name": String("Toby Fletcher"), "school":
String("Durango High School")}))

Para obtener más información sobre las operaciones en esta guía, consulte la siguiente documentación:

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:

Volver

Operaciones masivas