La interfaz de comandos de MongoDB brinda acceso a todos Operaciones de bases de datos no CRUD. Obtener estadísticas del servidor, inicializar un set de réplicas y ejecutar un pipeline de agregación o una tarea de map-reduce son tareas que se realizan con comandos.
Ver Comandos de base de datos para ver la lista de todos los comandos ordenados por función.
Formulario de comando de base de datos
Primero, se especifica un comando construyendo un documento BSON estándar cuya primera clave es el nombre del comando. Por ejemplo, especifique helloComando que utiliza el siguiente documento BSON:
{ hello: 1 }
Emitir Comandos
mongosh proporciona un método auxiliar para ejecutar comandos llamado. La db.runCommand() mongosh siguiente operación en ejecuta el comando anterior:
db.runCommand( { hello: 1 } )
Muchos Controladores proporcionan un equivalente para el db.runCommand() método. Internamente, ejecutar comandos con db.runCommand() es equivalente a una query especial sobre la colección $cmd.
Muchos comandos habituales tienen sus propios asistentes de shell o contenedores en mongosh y controladores, como el método db.hello() en mongosh.
Puede usar la opción maxTimeMS para especificar un límite de tiempo para la ejecución de un comando, consulte Terminar un Comando para obtener más información sobre la finalización de la operación.
admin Comandos de base de datos
Debe ejecutar algunos comandos en la base de datos admin. Normalmente, esas operaciones se parecen a las siguientes:
use admin db.runCommand( {buildInfo: 1} )
Sin embargo, también existe un asistente de comandos que ejecuta automáticamente el comando en el contexto de la admin base de datos:
db.adminCommand( {buildInfo: 1} )
Respuestas de los comandos
Para todos los comandos, MongoDB devuelve un documento de respuesta que contiene los siguientes campos:
Campo | Descripción |
|---|---|
<command result> | Campos de resultados específicos para el/la |
| Un número que indica si el comando tuvo éxito ( |
| El tiempo lógico de la operación. MongoDB utiliza el tiempo lógico para ordenar las operaciones. Solo para sets de réplicas y clústeres. Si el comando no genera una entrada en el registro de operaciones (por ejemplo, una operación de lectura), la operación no avanza el reloj lógico. En este caso,
Para las operaciones asociadas con sesiones causalmente coherentes, los drivers de MongoDB utilizan el tiempo lógico para establecer automáticamente el período de Operaciones de lectura y |
| Un documento que devuelve el tiempo de clúster firmado. El tiempo de clúster es un tiempo lógico utilizado para el ordenamiento de las operaciones. Sólo para sets de réplicas y clústeres fragmentados. Sólo para uso interno. El documento contiene los siguientes campos:
|