Overview
En esta guía, puedes aprender cómo remover documentos de tus colecciones de MongoDB usando operaciones de borrar.
Datos de muestra
Los ejemplos de esta guía utilizan el restaurants colección de la base de datos sample_restaurants. Los documentos de esta colección utilizan las siguientes clases Restaurant, Address y GradeEntry como modelos:
public class Restaurant { public ObjectId Id { get; set; } public string Name { get; set; } [] public string RestaurantId { get; set; } public string Cuisine { get; set; } public Address Address { get; set; } public string Borough { get; set; } public List<GradeEntry> Grades { get; set; } }
public class Address { public string Building { get; set; } [] public double[] Coordinates { get; set; } public string Street { get; set; } [] public string ZipCode { get; set; } }
public class GradeEntry { public DateTime Date { get; set; } public string Grade { get; set; } public float? Score { get; set; } }
Nota
Los documentos de la colección restaurants utilizan la convención de nomenclatura snake-case. Los ejemplos de esta guía utilizan un ConventionPack para deserializar los campos de la colección en notación Pascal y asignarlos a las propiedades de la clase Restaurant.
Para obtener más información sobre la serialización personalizada, consulta Serialización personalizada.
Esta colección es de la conjuntos de datos de muestra proporcionados por Atlas. Consulta la Guía de inicio rápido para aprender a crear un clúster gratuito de MongoDB y cargar estos datos de ejemplo.
Operaciones de borrar
Utilice operaciones de eliminación para eliminar documentos que coincidan con un filtro de query. El filtro de query determina qué registros se seleccionan para su eliminación según los criterios establecidos en el documento del filtro de query. Puedes realizar operaciones de eliminación en MongoDB con los siguientes métodos:
DeleteOne(), que elimina el primer documento que coincide con el filtro de queryDeleteMany()que elimina todos los documentos que coinciden con el filtro de query
Borrar un documento
El siguiente código muestra cómo usar el método asincrónico DeleteOneAsync() o el método sincrónico DeleteOne() para borrar un documento.
var result = await _restaurantsCollection.DeleteOneAsync(filter);
var result = _restaurantsCollection.DeleteOne(filter);
Borra varios documentos
El siguiente código muestra cómo usar el método asíncrono DeleteManyAsync() o el método sincrónico DeleteMany() para borrar todos los documentos coincidentes.
var result = await _restaurantsCollection.DeleteManyAsync(filter);
var result = _restaurantsCollection.DeleteMany(filter);
Tip
Encuentra ejemplos ejecutables utilizando estos métodos en información adicional.
Parámetros
Los métodos DeleteOne() y DeleteMany() requieren que pases un filtro de query especificando qué documentos deben coincidir. Más información sobre cómo construir un filtro de query está disponible en el tutorial documentos de query
Ambos métodos aceptan opcionalmente un tipo de DeleteOptions como parámetro adicional, el cual representa las opciones que se pueden utilizar para configurar la operación de borrado. Si no se especifica ninguna propiedad DeleteOptions, el driver no personaliza la operación de borrado.
El tipo DeleteOptions le permite configurar opciones con las siguientes propiedades:
Propiedad | Descripción |
|---|---|
| Gets or sets the type of language collation to use when sorting
results. See the delete
statements
for more information. |
| Gets or sets the comment for the operation. See the delete command
fields
for more information. |
| Gets or sets the index to use to scan for documents. See the delete
statements
for more information. |
| Gets or sets the let document. See the delete command
fields
for more information. |
Ejemplo
El siguiente código utiliza el método DeleteMany() para buscar en el índice "borough_1" y eliminar todos los documentos donde el valor del campo address.street incluye la frase "Pearl Street":
var filter = Builders<Restaurant>.Filter .Regex("address.street", "Pearl Street"); DeleteOptions opts = new DeleteOptions { Hint = "borough_1" }; Console.WriteLine("Deleting documents..."); var result = _restaurantsCollection.DeleteMany(filter, opts); Console.WriteLine($"Deleted documents: {result.DeletedCount}"); Console.WriteLine($"Result acknowledged? {result.IsAcknowledged}");
Deleting documents... Deleted documents: 26 Result acknowledged? True
Tip
Si el ejemplo anterior utilizara el método DeleteOne() en lugar de DeleteMany(), el driver borraría el primero de los 26 documentos coincidentes.
Valor de retorno
Los métodos DeleteOne() y DeleteMany() devuelven un tipo DeleteResult. Este tipo contiene la propiedad DeletedCount, que indica el número de documentos eliminados, y la propiedad IsAcknowledged, que indica si el resultado se reconoce. Si el filtro de query no coincide con ningún documento, no se borrarán documentos y DeletedCount será 0.
Información Adicional
Para ejemplos ejecutables de las operaciones de eliminación, consulta los siguientes ejemplos de uso:
Documentación de la API
Para obtener más información sobre cualquiera de los métodos o tipos discutidos en esta guía, consultar la siguiente documentación de la API: