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 hacen comparaciones entre tipos. Para más información, consulte Operadores de comparación.
Nota
MongoDB aplica comparaciones con Operadores de predicado de query de comparación solo en documentos donde el tipo BSON del campo de destino coincide con el tipo de operando de query mediante Delimitación de tipo.
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.
Strings
Comparación binaria
Por defecto, 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, consulta 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 arreglos:
Un orden ascendente compara los elementos más pequeños del arreglo según el orden de clasificación del tipo BSON.
Un ordenamiento descendente compara los elementos más grandes del arreglo según el orden de ordenamiento inverso del tipo BSON.
Operadores de predicado de query de comparación, como
$lty$gt, realizan comparaciones en arreglos de manera lexicográfica.Al 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 un arreglo vacío (por ejemplo,
[ ]) considera el arreglo vacío como 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
Operadores predicados de query de comparación aplican corchetes de tipo cuando la query es un arreglo. Si el valor indexado es un arreglo, el operador realiza una comparación por tipos entre corchetes elemento por elemento en el arreglo indexado.
Objetos
La comparación de objetos BSON de MongoDB utiliza el siguiente orden:
Compara 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, compara los nombres de los campos clave.
Si los nombres de los campos clave son iguales, compára los valores de los campos.
Si los valores de los campos son iguales, compara el siguiente par clave/valor (vuelve al paso 1). Un objeto sin pares adicionales es inferior a un objeto con pares adicionales.
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:
Primero, la longitud o el tamaño de los datos.
Luego, por el subtipo BSON de un solo byte.
Finalmente, mediante los datos, realizando una comparación byte a byte sobre bytes sin signo.