Al comparar valores de diferentes Tipos BSON en operaciones de clasificación, MongoDB utiliza el siguiente orden de comparación, del más bajo al más alto:
MinKey (tipo interno)
Nulo
Números (enteros, largos, dobles, decimales)
Símbolo, string
Objeto
Arreglo
BinData
ObjectId
Booleano
fecha
Marca de tiempo
Expresión regular
Código JavaScript
Código JavaScript con alcance
MaxKey (tipo interno)
Las expresiones de agregación permiten realizar comparaciones entre tipos. Para obtener más información, consulte Operadores de expresiones de comparación.
Nota
MongoDB aplica comparaciones con operadores de consulta de comparación solo en documentos donde el tipo BSON del campo de destino coincide con el tipo de operando de consulta a través del corchete de tipos.
Tipos numéricos
MongoDB trata algunos tipos como equivalentes a efectos de comparación. Por ejemplo, todos los tipos numéricos se consideran equivalentes en las comparaciones.
Instrumentos de cuerda
Comparación binaria
De forma predeterminada, MongoDB utiliza la comparación binaria simple para comparar cadenas.
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 especificación de intercalación tiene la siguiente sintaxis:
{ locale: <string>, caseLevel: <boolean>, caseFirst: <string>, strength: <int>, numericOrdering: <boolean>, alternate: <string>, maxVariable: <string>, backwards: <boolean> }
Al especificar la intercalación, el locale Este campo es obligatorio; todos los demás campos de intercalación son opcionales. Para obtener descripciones de los campos, consulte el documento de intercalació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.
Arreglos
En comparaciones de matrices:
Una ordenación ascendente compara los elementos más pequeños de la matriz según el orden de clasificación de tipo BSON.
Una ordenación descendente compara los elementos más grandes de la matriz según el orden de clasificación de tipo BSON inverso.
Losoperadores de consulta de comparación, como y, realizan
$ltcomparaciones en matrices lexicográficamente.$gtAl comparar un campo cuyo valor es una matriz de un elemento (por ejemplo,
[ 1 ]) con campos que no son matrices (por ejemplo,2), la comparación es para1y2.Una comparación de una matriz vacía (por ejemplo,
[ ]) considera que la matriz vacía es menor que un valornullo un valor de campo faltante.Una comparación de una matriz anidada (por ejemplo,
[[1, 2], [3, 4]]) compara lexicográficamente cualquier matriz después de la matriz más externa.
Nota
Los operadores de consulta de comparación aplican el uso de corchetes de tipo cuando la consulta es una matriz. Si el valor indexado es una matriz, el operador realiza una comparación con corchetes de tipo elemento por elemento sobre la matriz indexada.
Objetos
La comparación de objetos BSON de MongoDB utiliza el siguiente orden:
Compare recursivamente los pares clave-valor en el orden en que aparecen dentro del objeto BSON.
Comparar los tipos de campo. MongoDB utiliza el siguiente orden de comparación para los tipos de campo, de menor a mayor:
MinKey (tipo interno)
Nulo
Números (enteros, largos, dobles, decimales)
Símbolo, string
Objeto
Arreglo
BinData
ObjectId
Booleano
fecha
Marca de tiempo
Expresión regular
Código JavaScript
Código JavaScript con alcance
MaxKey (tipo interno)
Si los tipos de campo son iguales, compare los nombres de los campos clave.
Si los nombres de los campos clave son iguales, compare los valores de los campos.
Si los valores de los campos son iguales, compare el siguiente par clave-valor (regrese al paso 1). Un objeto sin más pares es menor que un objeto con más pares.
Fechas y marcas de tiempo
Los objetos de fecha se ordenan antes que los objetos de marca de tiempo.
Non-existent Fields
La comparación trata un campo inexistente como si fuera nulo. Una ordenación del campo a en los documentos { } y { a: null } trataría los documentos como equivalentes en el orden de clasificación.
BinData
MongoDB ordena BinData en el siguiente orden:
En primer lugar, la longitud o tamaño de los datos.
Luego, por el subtipo de un byte BSON.
Finalmente, a partir de los datos, se realiza una comparación byte a byte en los bytes sin signo.