Puede utilizar la búsqueda de MongoDB numberFacet escriba para indexar valores numéricos utilizando el representation especificado para facetar. Puedes indexar números de
BSON tipos int32, int64, y double.
MongoDB Search solo admite consultas del operador de faceta a campos indexados como el tipo numberFacet. Para realizar una búsqueda normal también en el mismo campo, debes indexar también el campo como tipo number.
Para realizar facetado en campos de string en documentos insertados, es necesario indexar los campos principales como tipo documento. Cuando se realiza un facetado en un campo de string dentro de documentos incrustados, MongoDB Search devuelve el recuento de facetas solo para el número de documentos principales que coinciden.
MongoDB Search no indexa dinámicamente los valores de number para la creación de facetas. Debes usar mapeos estáticos para indexar los valores number para las facetas. Puedes utilizar el Editor visual o el Editor JSON en la interfaz de usuario de Atlas para indexar number campos como el tipo number.
numberFacet Limitaciones de tipo
Se aplican las siguientes limitaciones:
No puedes indexar
decimal128para crear facetas.No puedes indexar valores numéricos en arreglos ni en un documento contenido en un arreglo para el facetado.
No puedes aplicar facetas sobre campos numéricos indexados como parte de un campo
embeddedDocuments.
Defina el índice para el numberFacet tipo
Para definir el índice para el tipo numberFacet, elige tu método de configuración preferido en la Interfaz de Usuario de Atlas y luego selecciona la base de datos y la colección.
Haga clic Refine Your Index para configurar su índice.
En la sección Field Mappings, haz clic en Add Field Mapping para abrir la ventana Add Field Mapping.
Haga clic en Customized Configuration.
Selecciona el campo para indicar desde el desplegable Field Name.
Nota
No puedes indexar campos que contengan el signo de dólar (
$) al inicio del nombre del campo.Haz clic en el desplegable Data Type y selecciona NumberFacet.
Configura las propiedades del campo para el tipo
numberFacet. Para obtener más información, consulte Propiedades del campo.Haga clic en Add.
A continuación, se muestra la sintaxis de JSON para el tipo numberFacet. Sustituye la definición del índice por defecto por la siguiente. Para obtener más información sobre los campos, consulta Propiedades de campo.
{ "mappings": { "dynamic": true|false, "fields": { "<field-name>": { "type": "numberFacet", "representation": "int64|double", "indexIntegers": true|false, "indexDoubles": true|false } } } }
Configurar las propiedades del campo numberFacet
El tipo numberFacet de búsqueda de MongoDB toma los siguientes parámetros:
Opción | Tipo | Necesidad | Descripción | predeterminado |
|---|---|---|---|---|
| string | Requerido | El tipo de campo. El valor debe ser | |
| string | Opcional | El tipo de dato del campo a indexar. Los valores pueden ser uno de los siguientes tipos de BSON:
Para obtener más información, consulte el ejemplo a continuación. |
|
| booleano | Opcional | Indica si indexar u omitir la indexación de los valores |
|
| booleano | Opcional | Indica si se indexan u omiten los valores de tipo |
|
Pruebe un ejemplo para el numberFacet tipo
El siguiente ejemplo de definición de índice utiliza la colección sample_mflix.movies. Si ya tienes los datos de muestras cargados en tu clúster, puedes usar el editor visual o el editor JSON en la Interfaz de Usuario de Atlas para configurar el índice. Después de seleccionar tu método de configuración preferido, selecciona la base de datos y la colección, y perfecciona tu índice para agregar mapeos de campos.
La siguiente definición de índice de ejemplo indexa el year campo como el tipo de búsqueda de MongoDB numberFacet para admitir consultas en ese campo mediante la faceta de búsqueda de MongoDB.
En la ventana Add Field Mapping, selecciona year del menú desplegable Field Name.
Haz clic en el desplegable Data Type y selecciona NumberFacet.
Acepta los valores por defecto para NumberFacet Properties.
Haga clic en Add.
Reemplazar la definición predeterminada del índice con la siguiente definición del índice.
{ "mappings": { "dynamic": false, "fields": { "year": { "type": "numberFacet" } } } }
El siguiente ejemplo de definición de índice indexa el campo year como tipos numberFacet y number para devolver los siguientes tipos de resultados para tus queries:
Resultados de metadatos para consultas que utilizan MongoDB Search
facet(Operador de búsqueda MongoDB).Resultados de búsqueda para consultas que utilizan operadores de MongoDB Search como cerca de, iguales y rango.
En la ventana Add Field Mapping, selecciona year del menú desplegable Field Name.
Haz clic en el desplegable Data Type y selecciona NumberFacet.
Acepta los valores por defecto para NumberFacet Properties.
Haga clic en Add.
Repite el paso 1 y selecciona Number del menú desplegable Data Type.
Acepta los valores por defecto para Number Properties.
Haga clic en Add.
Reemplazar la definición predeterminada del índice con la siguiente definición del índice.
{ "mappings": { "dynamic": false, "fields": { "year": [ { "type": "numberFacet" }, { "type": "number" } ] } } }
Obtén más información
Para aprender más sobre el colector facet y ver queries de ejemplo, consulte Ejemplos.
Para aprender a crear un índice con una definición de faceta y consultar ese índice utilizando el facet recopilador, consulte el tutorial Cómo usar facetas con la búsqueda de MongoDB.