Docs Menu
Docs Home
/ /
Consultar y escribir

find (comando de base de datos)

find

Ejecuta una query y devuelve el primer grupo de resultados y el ID del cursor, a partir del cual el cliente puede desarrollar un cursor.

Tip

mongoshEn, este comando también se puede ejecutar a través del db.collection.find() o métodos db.collection.findOne() auxiliares.

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.

Este comando está disponible en implementaciones alojadas en los siguientes entornos:

  • MongoDB Atlas: El servicio totalmente gestionado para implementaciones de MongoDB en la nube

Importante

Este comando tiene soporte limitado en los clústeres Flex y M0. Para obtener más información, consulta 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.

El comando find tiene la siguiente sintaxis:

Modificado en la versión 5.0.

db.runCommand(
{
find: <string>,
filter: <document>,
sort: <document>,
projection: <document>,
hint: <document or string>,
skip: <int>,
limit: <int>,
batchSize: <int>,
singleBatch: <bool>,
comment: <any>,
maxTimeMS: <int>,
readConcern: <document>,
max: <document>,
min: <document>,
returnKey: <bool>,
showRecordId: <bool>,
tailable: <bool>,
oplogReplay: <bool>,
noCursorTimeout: <bool>,
awaitData: <bool>,
allowPartialResults: <bool>,
collation: <document>,
allowDiskUse : <bool>,
let: <document> // Added in MongoDB 5.0
}
)

El comando acepta los siguientes campos:

Campo
Tipo
Descripción

find

string

El nombre de la colección o vista para hacer una query.

filter

Documento

Opcional. El predicado de la query. Si no se especifica, entonces todos los documentos de la colección coincidirán con el predicado.

Documento

Opcional. La especificación del orden para la clasificación de los resultados.

projection

Documento

Opcional. La especificación de proyección determina qué campos se incluirán en los documentos devueltos. Consulte Proyección y Operadores de proyección.

find() Las operaciones en las vistas no admiten los siguientes operadores de proyección:

hint

string o documento

Opcional. Especificación del índice. Especifica el nombre del índice como una string o el patrón de la clave del índice. Si se especifica, el sistema de query solo considerará los planes que utilicen el índice sugerido.

Con la siguiente excepción, hint es obligatorio si el comando incluye los campos min y/o max; hint no es obligatorio con min y/o max si filter es una condición de igualdad en el campo _id { _id: <value> }.

skip

Número entero positivo

Opcional. Número de documentos para omitir. Se establece por defecto en 0.

limit

Non-negative integer

Opcional. El número máximo de documentos para devolver. Si no se especifica, se establece por defecto en Sin límite. Un límite de 0 es equivalente a no establecer ningún límite.

batchSize

non-negative integer

Opcional. El número máximo de documentos que se pueden devolver en cada lote de un resultado de query. Por defecto, el comando find tiene un batchSize inicial mínimo de 101 documentos o 16 mebibytes (MiB) de documentos. Los grupos subsiguientes tienen un tamaño máximo de 16 MiB. Esta opción puede aplicar un límite inferior a 16 MiB, pero no uno mayor. Cuando se establece, el batchSize es el menor de batchSize documentos o 16 MiB de documentos.

Un batchSize de 0 significa que el cursor está establecido, pero no se devuelven documentos en el primer agrupamiento.

A diferencia de la versión anterior del protocolo de conexión, un batchSize de 1 para el comando find no cierra el cursor.

singleBatch

booleano

Opcional. Determina si se debe cerrar el cursor después del primer lote. Se configura por defecto en false.

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.).

Cualquier comentario establecido en un comando find es heredado por cualquier comando getMore posterior que se ejecute en el cursor find.

maxTimeMS

non-negative integer

Opcional.

Especifica un límite de tiempo en milisegundos. Si no especifica un valor para maxTimeMS, las operaciones no agotarán el tiempo de espera. Un valor de 0 especifica explícitamente el comportamiento por defecto sin límites.

MongoDB finaliza las operaciones que exceden su límite de tiempo asignado utilizando el mismo mecanismo que db.killOp(). MongoDB solo termina una operación en uno de sus puntos de interrupción designados.

Al especificar linearizable read concern, siempre utiliza maxTimeMS en caso de que la mayoría de los nodos que contienen datos no estén disponibles. maxTimeMS garantiza que la operación no se bloquee indefinidamente y, en su lugar, devuelva un error si no se puede cumplir el nivel de consistencia de lectura.

readConcern

Documento

Opcional. Especifica el nivel de consistencia de lectura.

La opción readConcern tiene la siguiente sintaxis: readConcern: { level: <value> }

Los posibles niveles de consistencia de lectura son estos:

Para obtener más información sobre los niveles de consistencia de lectura, consulta Nivel de consistencia de lectura.

El comando getMore utiliza el nivel readConcern especificado en el comando find de origen.

max

Documento

Opcional. El límite superior exclusivo para un índice específico. Consulta cursor.max() para obtener más detalles.

Para utilizar el campo max, el comando también debe usar hint, a menos que el filter especificado sea una condición de igualdad en el campo _id { _id: <value> }.

min

Documento

Opcional. El límite inferior inclusivo para un índice específico. Consulta cursor.min() para obtener más detalles.

Para utilizar el campo min, el comando también debe usar hint, a menos que el filter especificado sea una condición de igualdad en el campo _id { _id: <value> }.

returnKey

booleano

Opcional. Si es verdadero, devuelve únicamente las claves de índice en los documentos resultantes. El valor por defecto es falso. Si returnKey es verdadero y el comando find no usa un índice, los documentos devueltos estarán vacíos.

showRecordId

booleano

Opcional. Determina si se debe devolver el identificador del registro para cada documento. Si es verdadero, se agrega un campo $recordId a los documentos devueltos.

tailable

booleano

Opcional. Devuelve un cursor con seguimiento para una colección con tamaño fijo.

awaitData

booleano

Opcional. Utilízalo junto con la opción con seguimiento para bloquear temporalmente un comando getMore en el cursor al final de los datos en lugar de no devolver ningún dato. Después de un período de espera, find vuelve a la normalidad.

noCursorTimeout

booleano

Opcional. Impide que el servidor agote los cursores inactivos que no son parte de una sesión después de un periodo de inactividad de 30 minutos. Se ignora para los cursores que son parte de una sesión. Para obtener más información, consulta Tiempo de espera de inactividad de la sesión.

booleano

Opcional. Para las queries sobre una colección particionada, permite que el comando (o los comandos getMore posteriores) devuelvan resultados parciales, en lugar de un error, si una o más particiones consultadas no están disponibles.

Si find (o los comandos getMore subsiguientes) devuelven resultados parciales porque las particiones consultadas no están disponibles, la salida de búsqueda incluye un campo indicador partialResultsReturned. Si las particiones consultadas están disponibles para el comando inicial de find, pero una o más particiones dejan de estar disponibles para los comandos de getMore posteriores, solo los comandos de getMore que se ejecutan mientras las particiones no están disponibles incluyen partialResultsReturned en su salida.

collation

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:

collation: {
locale: <string>,
caseLevel: <boolean>,
caseFirst: <string>,
strength: <int>,
numericOrdering: <boolean>,
alternate: <string>,
maxVariable: <string>,
backwards: <boolean>
}

Al especificar la intercalación, el campo locale es obligatorio; todos los demás campos de intercalación son opcionales. Para las descripciones de los campos, consulta Documento de intercalación.

Si no se especifica la intercalación, pero la colección tiene una intercalación por defecto (ver db.createCollection()), la operación utiliza la intercalación especificada para la colección.

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.

booleano

Opcional.

Usa esta opción para anular allowDiskUseByDefault para una query específica. Puedes utilizar esta opción para lo siguiente:

  • Prohíbe el uso del disco en un sistema en que el uso del disco está permitido por defecto.

  • Permite el uso del disco en un sistema en que el uso del disco está prohibido por defecto.

A partir de MongoDB 6.0, si allowDiskUseByDefault está configurado en true y el servidor requiere más de 100 megabytes de memoria para una etapa de ejecución de pipeline, MongoDB guarda archivos temporales en el disco automáticamente, a menos que la query especifique { allowDiskUse: false }.

Para obtener más detalles, consulte allowDiskUseByDefault.

allowDiskUse no tiene ningún efecto si MongoDB puede satisfacer la clasificación especificada utilizando un índice, o si la clasificación en memoria requiere menos de 100 megabytes de memoria.

Para acceder una documentación más completa sobre allowDiskUse, consulta cursor.allowDiskUse().

Para obtener más información sobre las restricciones de memoria para grandes ordenaciones en memoria, consulta Uso de ordenación e índice.

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:

{
<variable_name_1>: <expression_1>,
...,
<variable_name_n>: <expression_n>
}

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 ($$) junto con el nombre de la variable en la forma $$<variable_name>. Por ejemplo: $$targetTotal.

Para usar una variable para los resultados del filtro, debes acceder a la variable dentro del operador $expr.

Para un ejemplo completo usando let y variables, vea Uso de variables en let.

Nuevo en la versión 5.0.

El comando devuelve un documento que contiene la información del cursor, incluyendo su ID y el primer lote de documentos. Por ejemplo, el siguiente documento se devuelve al ejecutarse en una colección fragmentada:

{
"cursor" : {
"firstBatch" : [
{
"_id" : ObjectId("5e8e2ca217b5324fa9847435"),
"zipcode" : "20001",
"x" : 1
},
{
"_id" : ObjectId("5e8e2ca517b5324fa9847436"),
"zipcode" : "30001",
"x" : 1
}
],
"partialResultsReturned" : true,
"id" : Long("668860441858272439"),
"ns" : "test.contacts"
},
"ok" : 1,
"operationTime" : Timestamp(1586380205, 1),
"$clusterTime" : {
"clusterTime" : Timestamp(1586380225, 2),
"signature" : {
"hash" : BinData(0,"aI/jWsUVUSkMw8id+A+AVVTQh9Y="),
"keyId" : Long("6813364731999420435")
}
}
}
Campo
Descripción

cursor

Contiene la información del cursor, incluyendo el cursor id y el firstBatch de los documentos.

Si la operación contra una colección particionada devuelve resultados parciales debido a la indisponibilidad de las particiones consultadas, el documento cursor incluye un campo partialResultsReturned. Para devolver resultados parciales, en lugar de un error, debido a la indisponibilidad de las particiones consultadas, el comando find debe ejecutarse con allowPartialResults configurado en true. Consulta allowPartialResults.

Si los fragmentos consultados están inicialmente disponibles para el comando find, pero una o más particiones dejan de estar disponibles en los comandos getMore posteriores, solo los comandos getMore que se ejecutan cuando una partición o particiones consultadas no están disponibles incluyen el indicador partialResultsReturned en la salida.

"ok"

Indica si el comando ha tenido éxito (1) o ha fallado (0).

Además de los campos específicos de find que se mencionaron anteriormente, db.runCommand() incluye la siguiente información para Set de réplicas y clústeres particionados:

  • $clusterTime

  • operationTime

Consulta los Resultados de db.runCommand() para obtener más detalles.

A partir de MongoDB 5.1, las opciones $regex options inválidas ya no se ignoran. Este cambio hace que $regex options sea más coherente con el uso de $regex en el comando aggregate y las queries de proyección.

Para los cursores creados dentro de una sesión, no puedes llamar a getMore fuera de la sesión.

De manera similar, para los cursores creados fuera de una sesión, no puedes llamar a getMore dentro de una sesión.

Los drivers de MongoDB y mongosh asocian todas las operaciones con una sesión de servidor, con la excepción de las operaciones de escritura no reconocidas. Para las operaciones no asociadas explícitamente a una sesión (es decir, mediante Mongo.startSession()), los drivers de MongoDB y mongosh crean una sesión implícita y la asocian con la operación.

Si una sesión está inactiva durante más de 30 minutos, MongoDB Server marca esa sesión como expirada y puede cerrarla en cualquier momento. Cuando MongoDB Server cierra la sesión, también finaliza cualquier operación en curso y cierra los cursores abiertos asociados con la sesión. Esto incluye cursores configurados con noCursorTimeout() o un maxTimeMS() mayor a 30 minutos.

Para las operaciones que devuelven un cursor, si el cursor puede estar inactivo durante más de 30 minutos, emita la operación dentro de una sesión explícita usando Mongo.startSession() y actualice periódicamente la sesión usando el comando refreshSessions. Consulte Tiempo de espera de inactividad de la sesión para obtener más información.

find puede usarse dentro de transacciones distribuidas.

  • Para los cursores creados fuera de una transacción, no puedes llamar a getMore dentro de la transacción.

  • Para los cursores creados en una transacción, no puedes llamar a getMore fuera de la transacción.

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.

Si el cliente que emitió find se desconecta antes de que la operación se complete, MongoDB marca find para su terminación usando killOp.

Al utilizar la Stable API V1, los siguientes campos de comando find no son compatibles:

  • awaitData

  • max

  • min

  • noCursorTimeout

  • oplogReplay

  • returnKey

  • showRecordId

  • tailable

A partir de MongoDB 6.0, un filtro de índice utiliza la intercalación establecida previamente mediante el comando planCacheSetFilter.

El siguiente comando ejecuta el comando find filtrando en el campo rating y en el campo cuisine. El comando incluye projection para devolver solo los siguientes campos en los documentos coincidentes: _id, name, rating y address.

El comando ordena los documentos en el conjunto de resultados por el campo name y limita el conjunto de resultados a 5 documentos.

db.runCommand(
{
find: "restaurants",
filter: { rating: { $gte: 9 }, cuisine: "italian" },
projection: { name: 1, rating: 1, address: 1 },
sort: { name: 1 },
limit: 5
}
)

Para anular el nivel de consistencia de lectura por defecto de "local", usa la opción readConcern.

La siguiente operación en un Set de réplicas especifica un nivel de consistencia de lectura de "majority" para leer la copia más reciente de los datos confirmados como están escritos en la mayoría de los nodos.

db.runCommand(
{
find: "restaurants",
filter: { rating: { $lt: 5 } },
readConcern: { level: "majority" }
}
)

Independientemente del nivel de consistencia de lectura, es posible que los datos más recientes de un nodo no reflejen la versión más reciente de los datos en el sistema.

El comando getMore usa el nivel readConcern especificado en el comando de origen find.

Se puede especificar readConcern para el método mongosh db.collection.find() usando el método cursor.readConcern():

db.restaurants.find( { rating: { $lt: 5 } } ).readConcern("majority")

Para obtener más información sobre los niveles de consistencia de lectura disponibles, consulta Nivel de consistencia de lectura.

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 ejecuta el comando find con la intercalación especificada:

db.runCommand(
{
find: "myColl",
filter: { category: "cafe", status: "a" },
sort: { category: 1 },
collation: { locale: "fr", strength: 1 }
}
)

mongosh proporciona cursor.collation() para especificar la intercalación para una operación db.collection.find().

Nuevo en la versión 5.0.

Para definir variables a las que puedes acceder en otros lugares del comando, utiliza la opción let.

Nota

Para filtrar los resultados usando una variable, debes acceder a la variable dentro del operador $expr.

Cree una colección cakeFlavors:

db.cakeFlavors.insertMany( [
{ _id: 1, flavor: "chocolate" },
{ _id: 2, flavor: "strawberry" },
{ _id: 3, flavor: "cherry" }
] )

El siguiente ejemplo define una variable targetFlavor en let y utiliza la variable para recuperar el sabor del pastel chocolate:

db.cakeFlavors.runCommand( {
find: db.cakeFlavors.getName(),
filter: { $expr: { $eq: [ "$flavor", "$$targetFlavor" ] } },
let : { targetFlavor: "chocolate" }
} )

Volver

borrar

En esta página