Para agentes de IA: um índice de documentação está disponível em https://www.mongodb.com/pt-br/docs/llms.txt — as versões de markdown de todas as páginas estão disponíveis anexando .md a qualquer caminho de URL.
Make the MongoDB docs better! We value your opinion. Share your feedback for a chance to win $100.
MongoDB Branding Shape
Click here >
Menu Docs

Exclua documentos

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 usam a collection restaurants no banco de dados sample_restaurants dos conjuntos de banco 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 aprender a criar um cluster MongoDB Atlas gratuito e carregar os conjuntos de dados de amostra, consulte o Guia de Introdução do MongoDB.

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

Especifica o tipo de agrupamento de idiomas a ser usado ao classificar os resultados. Para obter mais informações, consulte Agrupamento no manual do MongoDB Server .

write_concern

Define a preocupação de gravação para a operação. Para obter mais informações, consulte Write Concern no manual do MongoDB Server .

hint

Obtém ou define o índice para procurar documentos. Para obter mais informações, consulte a declaração de dica no manual do MongoDB Server .

let

Especifica um documento com uma lista de valores para melhorar a legibilidade da operação. Os valores devem ser expressões constantes ou fechadas que não façam referência aos campos do documento . Para obter mais informações, consulte a declaração let no manual do MongoDB Server .

comment

Anexa um comentário à operação. Para obter mais informações, consulte o guia de campos de comando de exclusão no manual do MongoDB Server .

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: