MongoDB con controladores
Esta página documenta a mongosh . Para ver el método equivalente en un driver de MongoDB, se debe consultar la página correspondiente al lenguaje de programación:
Definición
db.collection.deleteMany()Remueve todos los documentos que coincidan con
filterde una colección.Devuelve: Un documento que contiene: Un booleano
acknowledgedcomotruesi la operación se ejecutó con nivel de confirmación de escritura (write concern) ofalsesi el nivel de confirmación de escritura (write concern) estaba deshabilitadodeletedCountque contiene la cantidad de documentos eliminados
Nota
Si estás borrando todos los documentos de una colección grande, puede ser más rápido descartar la colección y recrearla. Antes de eliminar la colección, anota todos los índices de la colección. Debes recrear cualquier índice que existiera en la colección original. Si la colección original estaba particionada, también debes particionar la colección recreada.
Para obtener más información sobre cómo eliminar una colección, consulte db.collection.drop().
Compatibilidad
Este método está disponible en implementaciones alojadas en los siguientes entornos:
MongoDB Atlas: El servicio totalmente gestionado para implementaciones de MongoDB en la nube
Nota
Este comando es compatible con todos los clústeres de MongoDB Atlas. Para obtener información sobre el soporte de Atlas para todos los comandos, consulte Comandos no compatibles.
MongoDB Enterprise: La versión basada en suscripción y autogestionada de MongoDB
MongoDB Community: La versión de MongoDB con código fuente disponible, de uso gratuito y autogestionada.
Sintaxis
El método deleteMany() tiene la siguiente sintaxis:
db.collection.deleteMany( <filter>, { writeConcern: <document>, collation: <document>, hint: <document>|<string>, maxTimeMS: <int>, let: <document> } )
Parameter | Tipo | Descripción | ||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|
Documento | Especifica los criterios de borrado mediante operadores del query. Para borrar todos los documentos de una colección, pase un documento vacío ( | |||||||||||
Documento | Opcional. Un documento que expresa el nivel de confirmación de escritura. Omite el uso del nivel de confirmación de escritura por defecto. No establezcas explícitamente el nivel de confirmación de escritura para la operación si se ejecuta en una transacción. Para usar el nivel de confirmación de escritura con transacciones, consulta Transacciones y nivel de confirmación de escritura. | |||||||||||
Documento | Opcional. Especifica la intercalación a utilizar para la operación. La intercalación permite a los usuarios especificar reglas propias del lenguaje para la comparación de strings, como reglas para el uso de mayúsculas y minúsculas y marcas de acento. La opción de intercalación tiene la siguiente sintaxis: Al especificar la intercalación, el campo Si no se especifica la intercalación, pero la colección tiene una intercalación por defecto (ver Si no se especifica ninguna intercalación para la colección o para las operaciones, MongoDB utiliza la comparación binaria simple usada en versiones anteriores para las comparaciones de strings. No puedes especificar varias intercalaciones para una operación. Por ejemplo, no puedes especificar diferentes intercalaciones por campo, o si realizas una búsqueda con un ordenamiento, no puedes usar una intercalación para la búsqueda y otra para el ordenamiento. | |||||||||||
Documento | Opcional. Un documento o string que especifica el índice que se utilizará para soportar el predicado de query. La opción puede tomar un documento de especificación de índice o la string de nombre de índice. Si especifica un índice que no existe, la operación genera un error. Para ver un ejemplo, ve Especificar | |||||||||||
entero | Opcional. Especifica el límite de tiempo en milisegundos para que la operación de borrar se ejecute antes de que se agote el tiempo de espera. | |||||||||||
Documento | Opcional. Especifica un documento que contiene una lista de variables. Esto le permite mejorar la legibilidad de los comandos al separar las variables del texto de la query. La sintaxis del documento es: La variable se establece en el valor devuelto por la expresión y no puede modificarse posteriormente. Para acceder al valor de una variable en el comando, se debe usar el prefijo de doble signo de dólar ( Para usar una variable para los resultados del filtro, debes acceder a la variable dentro del operador Para un ejemplo completo usando |
Comportamiento
Colecciones fragmentadas
Si
deleteMany()se ejecuta fuera de una transacción, las operaciones que apuntan a más de una partición difunden la operación a todas las particiones del clúster.Si
deleteMany()se ejecuta dentro de una transacción, las operaciones que apuntan a más de una partición solo afectan a las particiones relevantes.
Advertencia
Debido a las migraciones simultáneas de fragmentos, deleteMany() podría ejecutarse sin borrar todos los documentos que coincidan con el filtro especificado. Para asegurarte de borrar todos los documentos coincidentes, realiza una de las siguientes operaciones:
Ejecuta el método
deleteMany()de forma iterativa hasta que el query correspondiente con el mismo filtro no devuelva ningún documento.Ejecuta
deleteMany()dentro de una transacción.Programa la ventana de balanceo para que las migraciones de fragmentos solo ocurran en momentos específicos, y ejecuta cualquier Operación
deleteMany()fuera de la ventana especificada.
Borrar un único documento
En cambio, para borrar un solo documento, use db.collection.deleteOne().
Como alternativa, utilice un campo que sea parte de un índice único como _id.
Transacciones
db.collection.deleteMany() puede usarse dentro de transacciones distribuidas.
No establezcas explícitamente el nivel de confirmación de escritura para la operación si se ejecuta en una transacción. Para usar el nivel de confirmación de escritura con transacciones, consulta Transacciones y nivel de confirmación de escritura.
Importante
En la mayoría de los casos, una transacción distribuida incurre en un costo de rendimiento mayor que las escrituras de documentos individuales, y la disponibilidad de transacciones distribuidas no debería ser un sustituto para un diseño de esquema efectivo. Para muchos casos, el modelo de datos desnormalizado (documento incrustado y matrices) seguirá siendo óptimo para tus datos y casos de uso. Es decir, en muchos casos, modelar tus datos de forma adecuada minimizará la necesidad de transacciones distribuidas.
Para consideraciones adicionales sobre el uso de transacciones (como el límite de tiempo de ejecución y el límite de tamaño del oplog), consulta también las consideraciones de producción.
Fallo del nodo primario
db.collection.deleteMany() borra documentos uno a la vez. Si el nodo primario falla durante una operación de db.collection.deleteMany(), los documentos que aún no se han borrados de los nodos secundarios no se borrarán de la colección.
Entradas de OpLog
Si una operación db.collection.deleteMany() borra correctamente uno o más documentos, la operación agrega una entrada para cada documento borrado en el oplog (registro de operaciones). Si la operación falla o no encuentra ningún documento para borrar, no agrega una entrada en el oplog.
Ejemplos
Los ejemplos de esta página utilizan datos del conjunto de datos de muestra sample_mflix. Para obtener más información sobre cómo cargar este conjunto de datos en la implementación autogestionada de MongoDB, consultar Cargar el conjunto de datos de muestra. Si se realizó alguna modificación en las bases de datos de muestra, es posible que se deban descartar y volver a crear las bases de datos para ejecutar los ejemplos de esta página.
Borra varios documentos
La siguiente operación elimina todos los documentos en los que year es anterior a 1910:
db.movies.deleteMany( { "year": { $lt: 1910 } } )
{ acknowledged: true, deletedCount: 4 }
Del mismo modo, esta operación elimina todos los document donde rated sea igual a "G" y year sea anterior a 1950:
db.movies.deleteMany( { "rated": "G", "year": { $lt: 1950 } } )
{ acknowledged: true, deletedCount: 9 }
deleteMany() con un tiempo de espera y variables de query
La siguiente operación elimina todos los document donde year sea anterior a la variable cutoffYear. El ejemplo también establece un límite de tiempo de 3 segundos:
db.movies.deleteMany( { $expr: { $lt: [ "$year", "$$cutoffYear" ] } }, { let: { cutoffYear: 1910 }, maxTimeMS: 3000 } )
{ acknowledged: true, deletedCount: 4 }
deleteMany() con nivel de confirmación de escritura (write concern)
Dado un set de réplicas de tres nodos, la siguiente operación especifica un w de majority y un wtimeout de 100:
db.movies.deleteMany( { "rated": "G", "year": { $lt: 1950 } }, { writeConcern: { w: "majority", wtimeout: 100 } } )
{ acknowledged: true, deletedCount: 9 }
Si el reconocimiento tarda más que el límite de wtimeout, MongoDB arroja un error de nivel de confirmación de escritura (write concern).
Especificar la intercalación
La intercalación permite a los usuarios especificar reglas propias del lenguaje para la comparación de strings, como reglas para el uso de mayúsculas y minúsculas y marcas de acento.
La siguiente operación usa la opción de intercalación con localización de inglés y strength: 2. El filtro rated: "g" coincide con los document con rated: "G" almacenados en la colección:
db.movies.deleteMany( { rated: "g", year: { $lt: 1950 } }, { collation: { locale: "en", strength: 2 } } )
{ acknowledged: true, deletedCount: 9 }
Especifique hint para las operaciones de borrado
Cree índices en los campos rated y metacritic:
db.movies.createIndex( { rated: 1 } ) db.movies.createIndex( { metacritic: 1 } )
La siguiente operación de eliminación indica explícitamente que se debe usar el índice { rated: 1 }:
db.movies.deleteMany( { "metacritic": { $lte: 15 }, "rated": "PG" }, { hint: { rated: 1 } } )
{ acknowledged: true, deletedCount: 7 }
Nota
Si especifica un índice que no existe, la operación genera un error.
Para ver los índices utilizados, puede usar el pipeline $indexStats:
db.movies.aggregate( [ { $indexStats: { } }, { $sort: { name: 1 } } ] )
El campo accesses.ops en el resultado $indexStats indica la cantidad de operaciones que usaron el índice.