Menu Docs
Página inicial do Docs
/ / /
Driver C++
/

Exclua documentos

Nesta página

  • Visão geral
  • Dados de amostra
  • Excluir operações
  • Excluir um documento
  • Excluir vários documentos
  • Personalizar a operação de exclusão
  • Valor de retorno
  • Documentação da API

Neste guia, você pode aprender como usar o driver C++ para remover documentos de uma coleção MongoDB executando operações de exclusão.

Uma operação de exclusão remove um ou mais documentos de uma collection do MongoDB. Você pode executar uma operação de exclusão utilizando os métodos delete_one() ou delete_many() .

Os exemplos neste guia utilizam a coleção do restaurants no banco de dados de dados do sample_restaurants a partir dos conjuntos de dados de amostra do Atlas. Para acessar essa coleção a partir do seu aplicação C++ , instancie um mongocxx::client que se conecte a um Atlas cluster e atribua os seguintes valores às suas variáveis db e collection :

auto db = client["sample_restaurants"];
auto collection = db["restaurants"];

Para saber como criar um cluster MongoDB Atlas gratuito e carregar os conjuntos de dados de amostra, consulte o guia Iniciar com Atlas .

Você pode executar operações de exclusão usando os seguintes métodos:

  • delete_one(), que exclui o primeiro documento que corresponde aos critérios do Atlas Search

  • delete_many(), que exclui todos os documentos que correspondem aos critérios do Atlas Search

Cada método de exclusão requer um query filtro documento, que especifica os critérios de pesquisa para determinar quais documentos selecionar para remoção. Para obter mais informações sobre filtros de query, consulte a seção Documentos de filtro de query no manual do MongoDB Server .

O exemplo a seguir usa o método delete_one() para remover um documento na collection restaurants que tem um valor name de "Ready Penny Inn":

auto result = collection.delete_one(make_document(kvp("name", "Ready Penny Inn")));

O exemplo a seguir usa o método delete_many() para remover todos os documentos na collection restaurants que tenham um valor borough de "Brooklyn":

auto result = collection.delete_many(make_document(kvp("borough", "Brooklyn")));

Você pode modificar o comportamento dos métodos delete_one() e delete_many() passando uma instância da classe mongocxx::options::delete_options como parâmetro opcional. A tabela seguinte descreve os campos que você pode definir em uma instância do mongocxx::options::delete_options :

Campo
Descrição

collation

Specifies the kind of language collation to use when sorting results. For more information, see Collation in the MongoDB Server manual.

write_concern

Sets the write concern for the operation. For more information, see Write Concern in the MongoDB Server manual.

hint

Gets or sets the index to scan for documents. For more information, see the hint statement in the MongoDB Server manual.

let

Specifies a document with a list of values to improve operation readability. Values must be constant or closed expressions that don't reference document fields. For more information, see the let statement in the MongoDB Server manual.

comment

Attaches a comment to the operation. For more information, see the delete command fields guide in the MongoDB Server manual.

O exemplo seguinte chama o método delete_many() para excluir todos os documentos na coleção restaurants que têm um valor name contendo a string "Mongo". Ele também define o campo comment de uma instância mongocxx::options::delete_options para adicionar um comentário à operação:

mongocxx::options::delete_options opts{};
opts.comment(bsoncxx::types::bson_value::view_or_value{"Deleting Mongo restaurants"});
auto query_filter = make_document(kvp("name", make_document(kvp("$regex", "Mongo"))));
auto result = collection.delete_many(query_filter.view(), opts);

Dica

Se o exemplo anterior usasse o método delete_one() em vez de delete_many(), o driver excluiria apenas o primeiro documento que tivesse um valor name contendo "Mongo".

Os métodos delete_one() e delete_many() retornam uma instância da classe mongocxx::result::delete_result . Esta classe contém as seguintes funções de membro:

  • result(), que retorna o resultado bruto da gravação em massa

  • deleted_count(), que retorna o número de documentos excluídos

Se o filtro de query não corresponder a nenhum documento, o driver não excluirá nenhum documento e deleted_count será 0.

O exemplo a seguir chama o método delete_many() para excluir documentos que tenham um valor cuisine de "Greek". Em seguida, ele chama a função de membro deleted_count() para imprimir o número de documentos excluídos:

auto result = collection.delete_many(make_document(kvp("cuisine", "Greek")));
std::cout << result->deleted_count() << std::endl;
Deleted documents: 111

Para saber mais sobre qualquer um dos métodos ou tipos discutidos neste guia, consulte a seguinte documentação da API:

Voltar

Substituir