Visão geral
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() .
Dados de amostra
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.
Excluir operações
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 Searchdelete_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 .
Excluir um documento
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")));
Excluir vários documentos
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")));
Personalizar a operação de exclusão
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 |
|---|---|
| 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 . |
| Define a preocupação de gravação para a operação. Para obter mais informações, consulte Write Concern no manual do MongoDB Server . |
| 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 . |
| 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 . |
| 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".
Valor de retorno
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 massadeleted_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
Documentação da API
Para saber mais sobre qualquer um dos métodos ou tipos discutidos neste guia, consulte a seguinte documentação da API: