Este tutorial demuestra cómo ejecutar consultas específicas de cadenas en campos que no son cadenas, convirtiendo los campos a cadenas y almacenándolos en un vista materializada. La vista materializada permite usar operadores específicos de cadena para consultar los campos convertidos y mantener los datos originales intactos en la colección de origen.
Este tutorial sigue estos pasos:
Antes de comenzar, asegúrese de que su clúster cumpla con los requisitos descritos en los prerrequisitos.
Crear una vista materializada
Esta sección demuestra cómo crear una Vista materializada denominada airbnb-mat-view en la sample_airbnb.listingsAndReviews colección. Esta vista almacena diversos campos numéricos y de fecha de la colección de origen como campos de tipo string.
Crea índices de búsqueda de MongoDB en la vista materializada
Para ejecutar las consultas en la etapa Ejecutar consultas en los campos convertidos de este tutorial, debe crear índices de búsqueda de MongoDB en los campos de cadena convertidos en su airbnb_mat_view vista materializada.
Las siguientes definiciones de JSON definen los índices de MongoDB Search en la vista materializada airbnb_mat_view. Puedes usar mapas dinámicos o estáticos para especificar cuáles campos deseas indexar en tu colección, dependiendo del tipo de query que desees ejecutar. Para obtener más información sobre las asignaciones de campos o la sintaxis de índices de la búsqueda de MongoDB, consulta Definir asignaciones de campo o Referencia de índice, respectivamente.
La siguiente definición de índice de búsqueda JSON MongoDB Search utiliza mapeos dinámicos para indexar los campos en la vista materializada. Puedes utilizar este índice para ejecutar consultas usando el operador queryString.
No puedes ejecutar consultas usando el operador de autocompletado en campos indexados dinámicamente.
{ "mappings": { "dynamic": true } }
La siguiente definición del índice de búsqueda JSON en MongoDB utiliza asignaciones estáticas para indexar los campos en la vista materializada como el tipo de autocompletado. Se puede utilizar este índice para ejecutar consultas utilizando el operador de autocompletado.
No puedes ejecutar consultas utilizando el operador queryString en campos indexados como tipo autocomplete.
{ "mappings": { "dynamic": false, "fields": { "accommodatesNumber": [ { "dynamic": true, "type": "document" }, { "minGrams": 1, "type": "autocomplete" } ], "lastScrapedDate": [ { "dynamic": true, "type": "document" }, { "type": "autocomplete" } ], "maximumNumberOfNights": [ { "dynamic": true, "type": "document" }, { "minGrams": 1, "type": "autocomplete" } ] } } }
Para aprender cómo crear los índices definidos anteriormente usando tu interfaz preferida, consulta Clientes compatibles.
Ejecutar consultas en los campos convertidos
Se pueden ejecutar consultas sobre los campos numéricos y de fecha que se convirtieron en cadenas. Este tutorial utiliza los operadores queryString y autocompletar para buscar propiedades. La consulta utiliza las siguientes etapas de la pipeline:
$searchescenario para buscar en la colecciónEtapa
$limitpara limitar la salida a resultados5$projectetapa que se debe excluir_id
En esta sección, te conectas a tu clúster y ejecutas las consultas de muestra utilizando el operador sobre los campos en la colección airbnb_mat_view.