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
/ /

$mod (operador predicado de query)

$mod

Selecciona documentos donde el valor de un campo dividido por un divisor tenga el resto especificado. Es decir, $mod realiza una operación de módulo para seleccionar documentos. El primer argumento es el dividendo y el segundo, el resto.

Para especificar una expresión $mod, utilice la siguiente sintaxis:

{ field: { $mod: [ divisor, remainder ] } }

$mod devuelve un error si el arreglo [ divisor, remainder ] no contiene dos elementos. Para ejemplos, consulta Error de elementos insuficientes y Error de demasiados elementos respectivamente.

Además, a partir de MongoDB 5.1 (y 5.0.4), $mod devuelve un error si los valores de divisor o remainder se evalúan como:

  • NaN (no es un número).

  • Infinity.

  • Un valor que no puede representarse utilizando un entero de 64 bits.

Si un documento en la colección contiene un campo cuyo valor es NaN (no es un número) o Infinity, $mod no incluye el documento en la salida.

Cuando el dividendo es negativo, el resto también es negativo. Para obtener más detalles sobre este comportamiento, consulta la documentación oficial de JavaScript.

Para un ejemplo, consulta Dividendo Negativo.

Crear una colección inventory:

db.inventory.insertMany( [
{ _id: 1, item: "abc123", qty: 0 },
{ _id: 2, item: "xyz123", qty: 5 },
{ _id: 3, item: "ijk123", qty: 12 }
] )

Luego, la siguiente query selecciona los documentos en la colección inventory donde el valor del campo qty módulo 4 es igual a 0:

db.inventory.find( { qty: { $mod: [ 4, 0 ] } } )

La query devuelve los siguientes documentos:

[
{ _id: 1, item: 'abc123', qty: 0 },
{ _id: 3, item: 'ijk123', qty: 12 }
]

El operador $mod genera un error cuando se le pasa un arreglo con menos de dos elementos.

La siguiente operación pasa incorrectamente al operador $mod un arreglo que contiene un solo elemento:

db.inventory.find( { qty: { $mod: [ 4 ] } } )

La instrucción da como resultado el siguiente error:

MongoServerError: malformed mod, not enough elements

La siguiente operación pasa incorrectamente el operador a una matriz $mod vacía:

db.inventory.find( { qty: { $mod: [ ] } } )

La instrucción da como resultado el siguiente error:

MongoServerError: malformed mod, not enough elements

El operador genera errores cuando se le pasa una matriz con más de dos $mod elementos.

Por ejemplo, la siguiente operación intenta utilizar el operador $mod con un arreglo que contiene cuatro elementos:

db.inventory.find( { qty: { $mod: [ 4, 1, 2, 3 ] } } )

La instrucción da como resultado el siguiente error:

MongoServerError: malformed mod, too many elements

La expresión $mod redondea la entrada decimal hacia cero.

Los siguientes ejemplos demuestran este comportamiento:

Ejemplo

Input query:

db.inventory.find( { qty: { $mod: [ 4.0, 0 ] } } )

Resultados:

[
{ _id: 1, item: 'abc123', qty: 0 },
{ _id: 3, item: 'ijk123', qty: 12 }
]

Ejemplo

Input query:

db.inventory.find( { qty: { $mod: [ 4.5, 0 ] } } )

Resultados:

[
{ _id: 1, item: 'abc123', qty: 0 },
{ _id: 3, item: 'ijk123', qty: 12 }
]

Ejemplo

Input query:

db.inventory.find( { qty: { $mod: [ 4.99, 0 ] } } )

Resultados:

[
{ _id: 1, item: 'abc123', qty: 0 },
{ _id: 3, item: 'ijk123', qty: 12 }
]

Cada consulta aplica 4 a la expresión $mod independientemente de los puntos decimales, lo que da como resultado el mismo conjunto de resultados.

La expresión $mod produce un resultado negativo cuando el dividendo es negativo.

El siguiente ejemplo demuestra este comportamiento:

Ejemplo

Input query:

db.inventory.find( { qty: { $mod: [ -4, -0 ] } } )

Esta query devuelve dos documentos porque el qty tiene un residuo de -0 cuando el dividendo es negativo y -0 es igual a 0 en JavaScript. Para obtener detalles sobre esta igualdad, consulte la documentación oficial de JavaScript.

Resultados:

[
{ _id: 1, item: 'abc123', qty: 0 },
{ _id: 3, item: 'ijk123', qty: 12 }
]

Volver

$jsonSchema

En esta página