Join us at MongoDB.local London on 7 May to unlock new possibilities for your data. Use WEB50 to save 50%.
Register now >
Docs Menu
Docs Home
/ /

renameCollection (comando de base de datos)

renameCollection

Cambia el nombre de una colección existente. Especifique los nombres de las colecciones para renameCollection en el formulario de un completo namespace (<database>.<collection>).

Tip

En mongosh, este comando también puede ejecutarse a través del método asistente renameCollection().

Los métodos asistente son convenientes para usuarios de mongosh, pero es posible que no proporcionen el mismo nivel de información que los comandos de base de datos. En los casos en que no se necesite la conveniencia o se requieran campos de retorno adicionales, utiliza el comando de base de datos.

Ejecute el comando renameCollection en la base de datos admin.

Este comando 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.

A partir de MongoDB 8.1, renameCollection se incluye en la versión V1 de la Stable API. Para utilizar renameCollection en la Stable API, debes conectar tu driver a una implementación que esté ejecutando MongoDB 8.1 o superior.

El comando tiene la siguiente sintaxis:

db.runCommand(
{
renameCollection: "<source_namespace>",
to: "<target_namespace>",
dropTarget: <true|false>,
writeConcern: <document>,
comment: <any>
}
)

El comando contiene los siguientes campos:

Campo
Tipo
Descripción

renameCollection

string

El namespace de la colección que se desea renombrar. El namespace es una combinación del nombre de la base de datos y el nombre de la colección.

to

string

El nuevo namespace de la colección. Si el nuevo namespace especifica una base de datos diferente, el comando renameCollection copia la colección en la nueva base de datos y descarta la colección de origen. Consulta restricciones de denominación.

dropTarget

booleano

opcional. Si true, mongod descartará el target de renameCollection antes de cambiar el nombre de la colección. El valor por defecto es false.

writeConcern

Documento

Opcional. Un documento que expresa el nivel de confirmación de escritura para la operación. Omite usar el nivel de confirmación de escritura por defecto.

Cuando se emite en un clúster particionado, mongos convierte el nivel de confirmación de escritura del comando renameCollection y su asistente db.collection.renameCollection() a "majority".

comment

any

Opcional. Un comentario proporcionado por el usuario para adjuntar a este comando. Una vez configurado, este comentario aparece junto a los registros de este comando en las siguientes ubicaciones:

Un comentario puede ser de cualquier tipo BSON válido (string, objeto, arreglo, etc.).

A partir de MongoDB 5.0, puedes utilizar el comando renameCollection para cambiar el nombre de una colección particionada. La base de datos de destino debe ser la misma que la base de datos de origen.

Puedes usar renameCollection para renombrar una colección no particionada en un clúster particionado siempre que las bases de datos de origen y destino tengan la misma partición primaria.

No puede utilizar renameCollection para renombrar una colección de series de tiempo. Para obtener más información, consulte Limitaciones de la colección de series de tiempo.

renameCollection falla si target es el nombre de una colección existente y no especificas dropTarget: true.

renameCollection tiene diferentes implicaciones en el rendimiento dependiendo del objetivo namespace.

Si la base de datos de destino es la misma que la base de datos de origen, renameCollection simplemente cambia el namespace. Esta es una operación rápida.

Si la base de datos de destino difiere de la base de datos de origen, renameCollection copia todos los documentos de la colección de origen a la colección de destino. Dependiendo del tamaño de la colección, esto puede tardar más en completarse.

Modificado en la versión 5.0.

Al cambiar el nombre de una colección particionada o no particionada en un clúster, las colecciones de origen y destino se bloquean exclusivamente en cada partición. Las operaciones posteriores en las colecciones de origen y destino deben esperar hasta que se complete la operación de cambio de nombre.

Para obtener más información sobre el bloqueo en MongoDB, consulta FAQ: Concurrency.

Si se renombra una colección dentro de la misma base de datos, renameCollection obtiene un bloqueo exclusivo en las colecciones de origen y destino durante la operación. Todas las operaciones posteriores en las colecciones deben esperar hasta que renameCollection se complete.

Si se cambia el nombre de una colección entre diferentes bases de datos, renameCollection obtiene un bloqueo exclusivo (W) en la base de datos de destino, un bloqueo de intención compartido (r) en la base de datos de origen y un bloqueo compartido (S) en la colección de origen. Las operaciones posteriores en la base de datos de destino deben esperar hasta que renameCollection libere el bloqueo exclusivo de base de datos.

Para obtener más información sobre el bloqueo en MongoDB, consulta FAQ: Concurrency.

  • No puede renombrar una colección de una base de datos replicada a la base de datos local, que no está replicada.

  • No se puede cambiar el nombre de una colección de la base de datos local, que no está replicada, a una base de datos replicada.

Advertencia

El db.collection.renameCollection() método y el renameCollection comando invalidan los cursores abiertos. Esto crea un evento de invalidación para cualquier corriente de cambios existente abierta en la colección de origen o de destino, y también interrumpe las consultas que están devolviendo datos de la colección renombrada.

Se produce un error al mongodump iniciado con --oplog si un cliente emite el comando renameCollection durante el proceso de vaciados. Consulta mongodump.--oplog para obtener más información.

El siguiente ejemplo renombra una colección llamada orders en la base de datos test a orders2014 en la base de datos test.

db.adminCommand( { renameCollection: "test.orders", to: "test.orders2014" } )

mongosh provee el db.collection.renameCollection() asistente para el comando de renombrar colecciones dentro de la misma base de datos. Lo siguiente es equivalente al ejemplo anterior:

use test
db.orders.renameCollection( "orders2014" )

Volver

removeQuerySettings

En esta página