Docs Menu
Docs Home
/ /

Define las asignaciones de campos

Cuando se crea un índice de MongoDB Search, se puede especificar qué campos indexar utilizando los siguientes métodos:

  • Mapeos dinámicos: habilite MongoDB Search para indexar automáticamente todos los campos según un conjunto de tipos de campos predeterminado o configurado (typeSet).

  • Mapeos estáticos: Permiten especificar qué campos se deben indexar.

Por defecto, MongoDB Search deja de replicar cambios para índices superiores a 2.1 mil millones de objetos de índice en un set de réplicas o una sola partición, donde cada documento indexado o embeddedDocument anidado cuenta como un solo objeto. Esto significa que el índice sigue siendo consultable, pero se podrían obtener resultados desactualizados.

Si planea indexar campos que podrían exceder 2.1 mil millones de objetos, donde un objeto de índice es un documento de nivel superior o un documento incrustado, utilice el Opción de índicenumPartitions para particionar su índice (compatible solo con la implementación de nodos de búsqueda) o fragmentar su clúster.

No puedes indexar campos que contengan el signo de dólar ($) al inicio del nombre del campo.

La siguiente sintaxis muestra cómo habilitar MongoDB Search para indexar campos mediante asignaciones dinámicas y estáticas. Para obtener más información sobre las asignaciones dinámicas y estáticas, consulte Mapeos dinámicos y estáticos.

1{
2 "mappings": {
3 "dynamic": true|false | {
4 "typeSet": "<typeset-name>"
5 },
6 "fields": {
7 "<field-name>": {
8 "type": "<field-type>",
9 ...
10 },
11 ...
12 }
13 },
14 "typeSets": [
15 {
16 "name": "<typeset-name>",
17 "types": [
18 {
19 "type": "<field-type>",
20 ...
21 },
22 ...
23 ]
24 },
25 ...
26 ]
27}

Se puede configurar MongoDB Search con:

  • Mapeos dinámicos para indexar automáticamente los campos según un conjunto por defecto o configurado de tipos (typeSet)

  • Mapeos estáticos para indexar solo campos especificados

También puede utilizar asignaciones dinámicas con asignaciones estáticas. Las asignaciones estáticas tienen prioridad sobre la configuración de las asignaciones dinámicas.

Los mapeos dinámicos de MongoDB Search permiten configurar MongoDB Search para indexar automática y recursivamente los campos en los datos. Los campos se pueden indexar en función del conjunto de tipos por defecto o configurando un typeSet.

Se pueden activar o configurar mapeos dinámicos:

  • En el nivel raíz mappings para aplicarse a todo el documento.

  • [Recomendado] Dentro de un tipo de campo document para aplicarlo a un objeto especificado.

  • [Recomendado] Dentro de un tipo de campo embeddedDocuments para aplicar a un arreglo especificado de objetos que requieren comparaciones de queries elemento por elemento (similar a $elemMatch).

Nota

Mejores prácticas

Los mapeos dinámicos podrían resultar en la indexación de un alto número de campos únicos, lo que ocupará más espacio en disco y podría ser menos eficiente. Se deben utilizar únicamente asignaciones dinámicas si se necesita crear un índice de campos que cambian regularmente o que son desconocidos. Siempre se deben utilizar asignaciones dinámicas dentro de un documento, no a nivel del documento principal.

Tip

Cuando se utilizan mapeos dinámicos para crear un índice para los datos:

  • MongoDB Search también indexa dinámicamente todos los campos anidados admitidos por el typeSet en un objeto document en los datos.

  • Si un campo contiene datos polimórficos, MongoDB Search indexa automáticamente el campo como todos los tipos admitidos por el typeSet utilizado en el índice. Si un campo contiene datos de un tipo no compatible con typeSet, MongoDB Search no indexará esos datos.

MongoDB Search usa el valor predeterminado typeSet cuando dynamic se establece en true. En el valor predeterminado typeSet, MongoDB Search indexa TiposBSON como tipos de campo de MongoDB Search. La siguiente tabla muestra los tipos BSON que MongoDB Search indexa automáticamente como tipos de campo al usar el valor typeSet predeterminado. MongoDB Search también indexa automáticamente los siguientes tipos BSON cuando están contenidos en matrices y objetos.

Tipo BSON
Tipo de campo de búsqueda de MongoDB

Booleano

fecha

Double, entero de 32 bits, entero de 64 bits

ObjectId

String

UUID

Nulo

La siguiente es la sintaxis para activar el conjunto de tipos por defecto para las asignaciones dinámicas:

1{
2 "mappings": {
3 "dynamic": false
4 }
5}

Para ver ejemplos de índices que demuestran la indexación de todos los campos utilizando el valor por defecto typeSet, se puede consultar Ejemplos de mapeo dinámico.

Especificar los tipos de campos de MongoDB Search para la indexación de forma dinámica configurando un typeSet. Se puede configurar cualquier tipo de BSON para que se indexe automáticamente como cualquier tipo de campo de búsqueda de MongoDB, excepto document, embeddedDocuments, vector, o los tipos de campo obsoletos.

Un typeSet tiene la siguiente sintaxis:

Nota

No se puede configurar un typeSet desde la interfaz de usuario de Atlas Visual Editor. Utilice la interfaz de usuario Atlas JSON Editor en su lugar.

1{
2 "mappings": {
3 "dynamic": {
4 "typeSet": "<typeset-name>"
5 },
6 "fields": {
7 "<field-name>": {
8 "type": "<field-type>",
9 ...
10 },
11 ...
12 }
13 },
14 "typeSets": [
15 {
16 "name": "<typeset-name>",
17 "types": [
18 {
19 "type": "<field-type>"
20 },
21 ...
22 ]
23 },
24 ...
25 ]
26}

Antes de configurar un typeSet, se debe considerar lo siguiente:

  • No se puede definir el mismo tipo de campo varias veces en el mismo objeto typeSet. Solo se puede configurar una única definición typeSet para cada tipo de campo.

    Por ejemplo, no se pueden definir múltiples configuraciones para el tipo number en la misma definición de typeSet.

  • Se pueden configurar mapeos dinámicos con el analizador multi.

Para ejemplos de índice que demuestran el uso de la configuración personalizada de typeSet, consultar Ejemplos de mapeo dinámico.

Utilizar mapeos estáticos para configurar opciones de índice para campos que no se desea indexar dinámicamente, o para configurar un solo campo independientemente de otros en un índice. Cuando se utilizan asignaciones estáticas, MongoDB Search crea índices de búsqueda solo de los campos que se especifican en mappings.fields. También se pueden utilizar asignaciones estáticas para excluir campos del índice.

Para utilizar asignaciones estáticas para configurar las opciones de índice solo para algunos campos, se debe establecer mappings.dynamic en false y especificar el nombre del campo, tipo de dato y otras opciones de configuración para cada campo que se desee indexar. Se pueden especificar los campos en cualquier orden.

Si omite el campo mappings.dynamic, se establece por defecto en false.

1{
2 "mappings": {
3 "dynamic": true|false,
4 "fields": {
5 "<field-name>": {
6 "type": "<field-type>",
7 ...
8 },
9 ...
10 }
11 }
12}

Para definir el índice de un campo anidado, se deben definir los mapeos para cada campo principal de ese campo anidado. No se puede usar la notación de puntos para usar el índice de campos anidados de forma estática. Para ver ejemplos, se pueden consultar los Ejemplos o Ejemplo de mapeo combinado a continuación.

Se pueden utilizar mapeos estáticos para indexar campos como múltiples tipos. Para indexar un campo como varios tipos, se deben definir los tipos en el arreglo de definición del campo. Se puede indexar cualquier campo como cualquier tipo admitido usando mapeos estáticos. Para aprender más, se puede consultar Tipos de campos de MongoDB Search.

El siguiente ejemplo muestra la definición de un campo para la indexación del mismo como múltiples tipos.

1{
2 "mappings": {
3 "dynamic": true|false | {
4 "typeSet": "<type-set-name>"
5 },
6 "fields": {
7 "<field-name>": [
8 {
9 "type": "<field-type>",
10 ...
11 },
12 {
13 "type": "<field-type>",
14 ...
15 },
16 ...
17 ],
18 ...
19 }
20 }.
21 "typeSets": [
22 {
23 "name": "<typeset-name>",
24 "types": [
25 {
26 "type": "<field-type>"
27 },
28 ...
29 ]
30 },
31 ...
32 ]
33}

Para otros ejemplos de índices que demuestran mapeos estáticos, se puede consultar Ejemplo de mapeo estático.

MongoDB Search no admite los siguientes tipos de datos BSON:

  • Decimal128

  • Código JavaScript con alcance

  • Clave máxima

  • Min key

  • Expresión regular

  • Marca de tiempo

MongoDB Search almacena automáticamente campos de tipo string en mongot. Se pueden almacenar campos de todos los tipos de datos compatibles en MongoDB Search usando la opción Definir campos fuente almacenados en su índice de MongoDB Search en la definición del índice. Para aprender más sobre mongot y la arquitectura de nodos de MongoDB Search, se puede consultar Opciones de implementación de MongoDB Search.

La siguiente tabla enumera los tipos de datos BSON admitidos y los tipos de campos de MongoDB Search que se pueden utilizar para indexar los tipos de datos BSON. La tabla también indica los operadores y coleccionistas que se pueden usar para consultar los valores de los campos.

Tipo BSON
Tipo de campo de búsqueda de MongoDB
Operadores y recolectores

Operadores que admiten el tipo de datos en el arreglo.

Booleano

fecha

fecha

Double

Double

Double

entero de 32 bits

entero de 32 bits

entero de 64 bits

entero de 64 bits

Nulo

N/A

Objeto

Operadores que brindan soporte a los tipos de campo en el objeto.

Objeto

embeddedDocument (para un arreglo de objetos)

ObjectId

String

String

String

String

vector

Estos operadores no brindan soporte para un arreglo de strings.

MongoDB Search no incluye un tipo de campo para la indexación de valores nulos porque MongoDB Search indexa automáticamente los valores nulos tanto para campos indexados de forma estática como dinámica.

Obsoleto. Para aprender más sobre los tipos de campo de faceta obsoletos y sus contrapartes actualizadas, se puede consultar Comparación de tipos de campo para facetas.

Arreglo de valores de double o int.

Nota

Puede almacenar campos de todos los tipos de datos soportados en MongoDB Búsqueda usando la opción storedSource.

Los siguientes ejemplos utilizan la colección sample_mflix.movies para demostrar cómo configurar los campos para indexar usando mapeos dinámicos y estáticos. Si carga los datos de muestra, se pueden crear estos índices en la colección. Para aprender a crear índices de búsqueda de MongoDB, se puede consultar Inicio rápido de MongoDB Search.

Los siguientes ejemplos de definición de índices demuestran mapeos dinámicos.

El siguiente ejemplo de definición de índice demuestra mapeos estáticos.

Los siguientes ejemplos de definiciones de índices combinan mapeos dinámicos con mapeos estáticos.

Volver

Filtros de Token