Substituir um documento
Você pode substituir um documento em uma coleção ligando para o métodoreplace_one() em uma Collection
instância.
Passe os seguintes parâmetros para o método replace_one()
:
Filtro de query, que especifica os critérios a serem correspondidos
Documento de substituição, que contém os campos e valores que substituirão o primeiro documento correspondente
O replace_one()
método retorna um UpdateResult tipo que contém informações sobre os resultados da operação de substituição, como o número de documentos modificados.
Para saber mais sobre o método replace_one()
, consulte a seção Substituir um documento do guia Modificar documentos.
Exemplo
Este exemplo substitui um documento na coleção restaurants
do banco de banco de dados sample_restaurants
. O método replace_one()
substitui o primeiro documento no qual o valor do campo name
é "Landmark Coffee Shop"
por um novo documento.
Você pode acessar os documentos na coleção restaurants
como instâncias do tipo Document
ou um tipo de dados personalizado. Para especificar qual tipo de dados representa os dados da coleção, execute as seguintes ações nas linhas realçadas:
Para acessar documentos de coleção como documentos BSON, substitua o parâmetro de tipo
<T>
por<Document>
e o espaço reservado<struct or doc>
porreplace_doc
.Para acessar documentos de coleção como instâncias da estrutura
Restaurant
, substitua o parâmetro de tipo<T>
por<Restaurant>
e o espaço reservado<struct or doc>
porreplace_struct
. A estruturaRestaurant
é definida no topo do arquivo de código.
Selecione a aba Asynchronous ou Synchronous para ver o código correspondente para cada tempo de execução:
use std::env; use mongodb::{ bson::doc, Client, Collection }; use serde::{ Deserialize, Serialize }; struct Restaurant { borough: String, cuisine: String, name: 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 filter = doc! { "name": "Landmark Coffee Shop" }; let replace_doc = doc! { "borough": "Brooklyn", "cuisine": "Café/Coffee/Tea", "name": "Harvest Moon Café", }; let replace_struct = Restaurant { borough: "Brooklyn".to_string(), cuisine: "Café/Coffee/Tea".to_string(), name: "Harvest Moon Café".to_string(), }; // Replace <struct or doc> with the replace_struct or replace_doc variable let res = my_coll.replace_one(filter, <struct or doc>).await?; println!("Replaced documents: {}", res.modified_count); Ok(()) }
Replaced documents: 1
use std::env; use mongodb::{ bson::doc, sync::{ Client, Collection } }; use serde::{ Deserialize, Serialize }; struct Restaurant { borough: String, cuisine: String, name: 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 filter = doc! { "name": "Landmark Coffee Shop" }; let replace_doc = doc! { "borough": "Brooklyn", "cuisine": "Café/Coffee/Tea", "name": "Harvest Moon Café", }; let replace_struct = Restaurant { borough: "Brooklyn".to_string(), cuisine: "Café/Coffee/Tea".to_string(), name: "Harvest Moon Café".to_string(), }; // Replace <struct or doc> with the replace_struct or replace_doc variable let res = my_coll.replace_one(filter, <struct or doc>).run()?; println!("Replaced documents: {}", res.modified_count); Ok(()) }
Replaced documents: 1