Make the MongoDB docs better! We value your opinion. Share your feedback for a chance to win $100.
MongoDB Branding Shape
Click here >
Docs Menu

Usar vistas con MongoDB Search

Puedes crear un índice de búsqueda de MongoDB en una Vista para transformar documentos y colecciones. Esto le permite indexar parcialmente una colección, admitir tipos de datos o modelos de datos incompatibles, y más.

Los siguientes ejemplos utilizan las bases de datos de muestra sample_mflix y sample_airbnb.

Nota

Desambiguación

Esta página discute las vistas estándar. Para aprender más sobre las vistas materializadas on-demand, consulte Vistas materializadas On-demand.

Para aprender sobre las diferencias entre los tipos de vistas, se puede consultar Comparación con vistas materializadas on-demand.

Debes usar MongoDB 8.0 o superior.

  • En MongoDB v8.0+:

    • Utiliza la interfaz de usuario de Atlas o la API de administración de Atlas para crear índices de MongoDB Search en las vistas.

    • Ejecuta las queries de MongoDB Search en la colección de origen. Hace referencia al índice de MongoDB Search que se creó en la Vista. Estas queries devuelven los documentos originales tal como aparecen en la colección de origen.

  • En MongoDB v8.1+, también puedes:

Para editar una Vista, debes tener el rol de Administrador de Usuario y utilizar el comando collMod comando de base de datos.

  • MongoDB Search admite vistas con las siguientes etapas:

  • Los nombres de los índices deben ser únicos en toda una colección de fuente y todas sus vistas.

  • MongoDB Search no admite definiciones de vistas con operadores que generan resultados dinámicos, como la $$USER_ROLES variable del sistema y el $rand operador de agregación.

  • MongoDB Search queries devuelven los documentos originales tal como aparecen en la colección de origen.

  • Para recuperar el documento transformado, use la storedSource opción.

Para crear una Vista, tu rol debe tener el privilegio de createCollection.

Los siguientes ejemplos muestran cómo crear una vista, indexar parcialmente documentos y ejecutar consultas sobre la vista utilizando el índice.

Filtra documentos para indexar parcialmente una colección.

Puede filtrar documentos para indexar parcialmente una colección. El siguiente ejemplo crea una Vista sobre la colección sample_mflix.movies para que puedas buscar únicamente películas estrenadas después del 1 de enero de 2000.

1

Para obtener más información, consulte Conectarse a un clúster a través de mongosh.

2
use sample_mflix
3
db.createView(
"movies_ReleasedAfter2000",
"movies",
[
{
$match: {
$expr: {
$gt: [
"$released",
ISODate("2000-01-01")
]
}
}
}
]
)
4
  1. Si aún no se muestra, seleccione la organización que contiene su proyecto deseado en el menú Organizations de la barra de navegación.

  2. Si aún no aparece, selecciona el proyecto deseado en el menú Projects de la barra de navegación.

  3. En la barra lateral, haz clic en Clusters en la sección Database.

La página de clústeres se muestra.

5

Puedes ir a la página de búsqueda de MongoDB desde la opción Search & Vector Search o desde el Data Explorer.

  1. Si aún no aparece, se debe seleccionar la organización que contiene el proyecto en el menú Organizations de la barra de navegación.

  2. Si aún no se muestra, seleccione su proyecto en el menú Projects de la barra de navegación.

  3. En la barra lateral, haz clic en Search & Vector Search en la sección Database.

    • Si no tienes clústeres, haz clic en Create cluster para crear uno. Para obtener más información, consulta Crear un clúster.

    • Si el proyecto tiene varios clústeres, se debe seleccionar el clúster que se desea usar en el menú desplegable Select cluster y luego se debe hacer clic en Go to Search.

    Aparece la página de Búsqueda y Búsqueda Vectorial.

  1. Si aún no aparece, se debe seleccionar la organización que contiene el proyecto en el menú Organizations de la barra de navegación.

  2. Si aún no se muestra, seleccione su proyecto en el menú Projects de la barra de navegación.

  3. En la barra lateral, haz clic en Data Explorer en la sección Database.

  4. Expanda la base de datos y seleccione la colección.

  5. Haga clic en la pestaña Indexes para la colección.

  6. Haga clic en el enlace Search and Vector Search en el banner.

    Aparece la página de Búsqueda y Búsqueda Vectorial.

6
7

Realiza las siguientes selecciones en la página y luego haz clic en Next.

Search Type

Seleccione el tipo de índice MongoDB Search.

Index Name and Data Source

Especifique la siguiente información:

  • Index Name: releasedAfter2000Index

  • Database and Collection:

    • sample_mflix
    • movies_ReleasedAfter2000

Configuration Method

Para una experiencia guiada,Visual Editor seleccione.

Para editar la definición del índice sin procesar,JSON Editor seleccione.

IMPORTANTE: Tu índice |fts| se llama ``autoembed_index` por defecto. Si estás creando varios índices, te recomendamos que mantengas una convención de nombres coherente y descriptiva en todos tus índices.

8

Atlas muestra un mensaje emergente (notificación breve y no interactiva) para informar que el índice se está compilando.

9

El índice recién creado aparece en la pestaña Atlas Search. Mientras se está construyendo el índice, el campo Status muestra Build in Progress. Cuando se termina de construir el índice, el campo Status muestra Active.

IMPORTANTE: Las colecciones más grandes tardan más tiempo en indexarse. Se recibirá una notificación por correo electrónico cuando el índice haya terminado de construirse.

10

Haz clic en el botón Query a la derecha del índice que deseas consultar.

11

Haz clic en Edit Query para ver una muestra de sintaxis de query por defecto en formato JSON.

12

Nota

El siguiente ejemplo consulta el índice releasedAfter2000Index ejecutando el comando .aggregate en la Vista denominada movies_ReleasedAfter2000. Si tu clúster está ejecutando MongoDB v8.0, debes query la colección fuente (por ejemplo, movies) utilizando el índice en la Vista. Actualiza a MongoDB v8.1+ para query la Vista directamente.

[
{
"$search": {
"index": "releasedAfter2000Index",
"text": {
"path": "title",
"query": "foo"
},
"sort": {
"released": 1
}
}
}
]
SCORE: 3.120296001434326 _id: “573a13d2f29313caabd929f8”
awards: Object
cast: Array (4)
countries: Array (1)
directors: Array (1)
fullplot: "Rising from the ashes of Nirvana, the Foo Fighters became a Grammy-win…"
genres: Array (2)
imdb: Object
languages: Array (1)
lastupdated: "2015-08-19 00:00:25.937000000"
num_mflix_comments: 0
plot: "Rising from the ashes of Nirvana, the Foo Fighters became a Grammy-win…"
poster: "https://m.media-amazon.com/images/M/MV5BMzE4OTczMTgxM15BMl5BanBnXkFtZT…"
released: 2011-04-05T00:00:00.000+00:00
runtime: 150
title: "Foo Fighters: Back and Forth"
tomatoes: Object
type: "movie"
year: 2011
1

Para obtener más información, consulte Conectarse a un clúster a través de mongosh.

2
use sample_mflix
3
db.createView(
"movies_ReleasedAfter2000",
"movies",
[
{
$match: {
$expr: {
$gt: [
"$released",
ISODate("2000-01-01")
]
}
}
}
]
)
4
db.movies_ReleasedAfter2000.createSearchIndex(
"releasedAfter2000Index",
{
"mappings": {
"dynamic": true
}
}
)
5

Nota

El siguiente ejemplo consulta el índice releasedAfter2000Index ejecutando el comando .aggregate en la Vista denominada movies_ReleasedAfter2000. Si tu clúster está ejecutando MongoDB v8.0, debes query la colección fuente (por ejemplo, movies) utilizando el índice en la Vista. Actualiza a MongoDB v8.1+ para query la Vista directamente.

db.movies_ReleasedAfter2000.aggregate([
{
$search: {
index: "releasedAfter2000Index",
text: {
path: "title",
query: "foo"
},
sort: {
released: 1
}
}
}
])
[
{
_id: ObjectId('573a13d2f29313caabd929f8'),
plot: "Rising from the ashes of Nirvana, the Foo Fighters became a Grammy-winning sensation on their own. Sixteen years of the band's history comes to life in this documentary, from their demo ...",
genres: [ 'Documentary', 'Music' ],
runtime: 150,
cast: [
'Shawn Cloninger',
'William Goldsmith',
'Jessy Greene',
'Dave Grohl'
],
num_mflix_comments: 0,
poster: 'https://m.media-amazon.com/images/M/MV5BMzE4OTczMTgxM15BMl5BanBnXkFtZTcwNTU1NjQxOA@@._V1_SY1000_SX677_AL_.jpg',
title: 'Foo Fighters: Back and Forth',
fullplot: `Rising from the ashes of Nirvana, the Foo Fighters became a Grammy-winning sensation on their own. Sixteen years of the band's history comes to life in this documentary, from their demo tapes through the creation of their 2011 album, "Wasting Light."`,
languages: [ 'English' ],
released: ISODate('2011-04-05T00:00:00.000Z'),
directors: [ 'James Moll' ],
awards: { wins: 1, nominations: 1, text: '1 win & 1 nomination.' },
lastupdated: '2015-08-19 00:00:25.937000000',
year: 2011,
imdb: { rating: 8.4, votes: 3745, id: 1853563 },
countries: [ 'USA' ],
type: 'movie',
tomatoes: {
viewer: { rating: 4.4, numReviews: 857, meter: 96 },
dvd: ISODate('2011-08-08T00:00:00.000Z'),
website: 'http://us.foofightersfilm.com/',
production: 'Cinedigm Digital Cinema',
lastUpdated: ISODate('2015-09-12T18:42:01.000Z')
}
}
]

Agrega o modifica campos usando una vista.

El siguiente ejemplo permite buscar en la colección sample_airbnb.listingsAndReviews alojamientos basados en un nuevo campo totalPrice, que es la suma de los campos price y cleaningFee. Además, dado que MongoDB Search no admite tipos Decimal128, transformamos los valores a Double.

1

Para obtener más información, consulte Conectarse a un clúster a través de mongosh.

2
use sample_airbnb
3
db.createView(
"listingsAndReviews_totalPrice",
"listingsAndReviews",
[
{
$addFields: {
totalPrice: {
$add: [
{
$ifNull: [{ $toDouble: "$price" }, 0]
},
{
$ifNull: [{ $toDouble: "$cleaning_fee" }, 0]
}
]
}
}
}
]
)
4
  1. Si aún no se muestra, seleccione la organización que contiene su proyecto deseado en el menú Organizations de la barra de navegación.

  2. Si aún no aparece, selecciona el proyecto deseado en el menú Projects de la barra de navegación.

  3. En la barra lateral, haz clic en Clusters en la sección Database.

La página de clústeres se muestra.

5

Puedes ir a la página de búsqueda de MongoDB desde la opción Search & Vector Search o desde el Data Explorer.

  1. Si aún no aparece, se debe seleccionar la organización que contiene el proyecto en el menú Organizations de la barra de navegación.

  2. Si aún no se muestra, seleccione su proyecto en el menú Projects de la barra de navegación.

  3. En la barra lateral, haz clic en Search & Vector Search en la sección Database.

    • Si no tienes clústeres, haz clic en Create cluster para crear uno. Para obtener más información, consulta Crear un clúster.

    • Si el proyecto tiene varios clústeres, se debe seleccionar el clúster que se desea usar en el menú desplegable Select cluster y luego se debe hacer clic en Go to Search.

    Aparece la página de Búsqueda y Búsqueda Vectorial.

  1. Si aún no aparece, se debe seleccionar la organización que contiene el proyecto en el menú Organizations de la barra de navegación.

  2. Si aún no se muestra, seleccione su proyecto en el menú Projects de la barra de navegación.

  3. En la barra lateral, haz clic en Data Explorer en la sección Database.

  4. Expanda la base de datos y seleccione la colección.

  5. Haga clic en la pestaña Indexes para la colección.

  6. Haga clic en el enlace Search and Vector Search en el banner.

    Aparece la página de Búsqueda y Búsqueda Vectorial.

6

Realiza las siguientes selecciones en la página y luego haz clic en Next.

Search Type

Seleccione el tipo de índice MongoDB Search.

Index Name and Data Source

Especifique la siguiente información:

  • Index Name: totalPriceIndex

  • Database and Collection:

    • sample_airbnb
    • listingsAndReviews_totalPrice

Configuration Method

Seleccione JSON Editor para editar la definición del índice en bruto.

7

Copia y pega la siguiente definición de índice para reemplazar la definición de índice por defecto en la Interfaz de Usuario:

{
"mappings": {
"dynamic": true
},
"storedSource": {
"include": [
"totalPrice"
]
}
}
8

Atlas muestra un mensaje emergente (notificación breve y no interactiva) para informar que el índice se está compilando.

9

El índice recién creado aparece en la pestaña Atlas Search. Mientras se está construyendo el índice, el campo Status muestra Build in Progress. Cuando se termina de construir el índice, el campo Status muestra Active.

IMPORTANTE: Las colecciones más grandes tardan más tiempo en indexarse. Se recibirá una notificación por correo electrónico cuando el índice haya terminado de construirse.

10

Haz clic en el botón Query a la derecha del índice que deseas consultar.

11

Haz clic en Edit Query para ver una muestra de sintaxis de query por defecto en formato JSON.

12

Nota

El siguiente ejemplo consulta el índice totalPriceIndex ejecutando el comando .aggregate en la Vista denominada listingsAndReviews_totalPrice. Si tu clúster está ejecutando MongoDB v8.0, debes query la colección fuente (por ejemplo, listingsAndReviews) utilizando el índice en la Vista. Actualiza a MongoDB v8.1+ para query la Vista directamente.

[
{
"$search": {
"index": "totalPriceIndex",
"range": {
"path": "totalPrice",
"lte": 300
},
"returnStoredSource": true
}
}
]
SCORE: 1 _id: "10006546"
totalPrice: 115
SCORE: 1 _id: "1001265"
totalPrice: 215
SCORE: 1 _id: "10021707"
totalPrice: 40
SCORE: 1 _id: "1003530"
totalPrice: 270
SCORE: 1 _id: "10038496"
totalPrice: 269
SCORE: 1 _id: "10051164"
totalPrice: 250
SCORE: 1 _id: "10057447"
totalPrice: 50
SCORE: 1 _id: "10057826"
totalPrice: 205
SCORE: 1 _id: "10059244"
totalPrice: 43
SCORE: 1 _id: "10066928"
totalPrice: 140
1

Para obtener más información, consulte Conectarse a un clúster a través de mongosh.

2
use sample_airbnb
3
db.createView(
"listingsAndReviews_totalPrice",
"listingsAndReviews",
[
{
$addFields: {
totalPrice: {
$add: [
{
$ifNull: [{ $toDouble: "$price" }, 0]
},
{
$ifNull: [{ $toDouble: "$cleaning_fee" }, 0]
}
]
}
}
}
]
)
4
db.listingsAndReviews_totalPrice.createSearchIndex(
"totalPriceIndex",
{
"mappings": {
"dynamic": true
},
"storedSource": {
"include": [
"totalPrice"
]
}
}
)
5

Nota

El siguiente ejemplo consulta el índice totalPriceIndex ejecutando el comando .aggregate en la Vista denominada listingsAndReviews_totalPrice. Si tu clúster está ejecutando MongoDB v8.0, debes query la colección fuente (por ejemplo, listingsAndReviews) utilizando el índice en la Vista. Actualiza a MongoDB v8.1+ para query la Vista directamente.

db.listingsAndReviews_totalPrice.aggregate([
{
$search: {
index: "totalPriceIndex",
range: {
path: "totalPrice",
lte: 300
},
returnStoredSource: true
}
}
])
[
{ _id: '10006546', totalPrice: 115 },
{ _id: '1001265', totalPrice: 215 },
{ _id: '10021707', totalPrice: 40 },
{ _id: '1003530', totalPrice: 270 },
{ _id: '10038496', totalPrice: 269 },
{ _id: '10051164', totalPrice: 250 },
{ _id: '10057447', totalPrice: 50 },
{ _id: '10057826', totalPrice: 205 },
{ _id: '10059244', totalPrice: 43 },
{ _id: '10066928', totalPrice: 140 },
{ _id: '10082422', totalPrice: 60 },
{ _id: '10083468', totalPrice: 40 },
{ _id: '10084023', totalPrice: 231 },
{ _id: '10091713', totalPrice: 231 },
{ _id: '10092679', totalPrice: 58 },
{ _id: '10096773', totalPrice: 205 },
{ _id: '10112159', totalPrice: 90 },
{ _id: '10117617', totalPrice: 55 },
{ _id: '10120414', totalPrice: 150 },
{ _id: '10133554', totalPrice: 121 }
]

Configurar la indexación dinámica para campos con patrones de nomenclatura usando regex.

Para indexar campos que coincidan con un patrón de nomenclatura, utilice una vista para transformar sus datos de modo que los campos a indexar queden anidados en un subdocumento. Esto le permite usar asignaciones dinámicas para la ruta del subdocumento, de manera que pueda buscar automáticamente todos los campos nuevos con el _type sufijo, sin necesidad de modificar la definición del índice.

La siguiente View llamada listings_SearchableTypes solo coincide con los nombres de campos que terminan con _type en la colección sample_airbnb.listingsAndReviews. Específicamente, la etapa $set agrega un nuevo campo llamado searchable_types, que contiene los campos filtrados con el término _type en el nombre del campo. El $arrayToObject contiene la entrada del filtro (documento completo) y la condición (coincidencia de regex para _type).

1

Para obtener más información, consulte Conectarse a un clúster a través de mongosh.

2
use sample_airbnb
3
1db.createView(
2 "listings_SearchableTypes",
3 "listingsAndReviews",
4 [
5 {
6 "$set": {
7 "searchable_types": {
8 "$arrayToObject": {
9 "$filter": {
10 "input": { "$objectToArray": "$$ROOT" },
11 "cond": {
12 "$regexMatch": {
13 "input": "$$this.k",
14 "regex": /_type$/
15 }
16 }
17 }
18 }
19 }
20 }
21 }
22 ]
23)
4
  1. Si aún no se muestra, seleccione la organización que contiene su proyecto deseado en el menú Organizations de la barra de navegación.

  2. Si aún no aparece, selecciona el proyecto deseado en el menú Projects de la barra de navegación.

  3. En la barra lateral, haz clic en Clusters en la sección Database.

La página de clústeres se muestra.

5

Puedes ir a la página de búsqueda de MongoDB desde la opción Search & Vector Search o desde el Data Explorer.

  1. Si aún no aparece, se debe seleccionar la organización que contiene el proyecto en el menú Organizations de la barra de navegación.

  2. Si aún no se muestra, seleccione su proyecto en el menú Projects de la barra de navegación.

  3. En la barra lateral, haz clic en Search & Vector Search en la sección Database.

    • Si no tienes clústeres, haz clic en Create cluster para crear uno. Para obtener más información, consulta Crear un clúster.

    • Si el proyecto tiene varios clústeres, se debe seleccionar el clúster que se desea usar en el menú desplegable Select cluster y luego se debe hacer clic en Go to Search.

    Aparece la página de Búsqueda y Búsqueda Vectorial.

  1. Si aún no aparece, se debe seleccionar la organización que contiene el proyecto en el menú Organizations de la barra de navegación.

  2. Si aún no se muestra, seleccione su proyecto en el menú Projects de la barra de navegación.

  3. En la barra lateral, haz clic en Data Explorer en la sección Database.

  4. Expanda la base de datos y seleccione la colección.

  5. Haga clic en la pestaña Indexes para la colección.

  6. Haga clic en el enlace Search and Vector Search en el banner.

    Aparece la página de Búsqueda y Búsqueda Vectorial.

6

Realiza las siguientes selecciones en la página y luego haz clic en Next.

Search Type

Seleccione el tipo de índice MongoDB Search.

Index Name and Data Source

Especifique la siguiente información:

  • Index Name: listingsSearchableTypes

  • Database and Collection:

    • sample_airbnb
    • listings_SearchableTypes

Configuration Method

Seleccione JSON Editor para editar la definición del índice en bruto.

7

Copia y pega la siguiente definición de índice para reemplazar la definición de índice por defecto en la Interfaz de Usuario:

{
"analyzer": "lucene.standard",
"searchAnalyzer": "lucene.standard",
"mappings": {
"dynamic": false,
"fields": {
"searchable_types": [
{
"dynamic": {
"typeSet": "tokenTypeSet"
},
"type": "document"
}
]
}
},
"typeSets": [
{
"name": "tokenTypeSet",
"types": [
{
"type": "token"
}
]
}
]
}
8

Atlas muestra un mensaje emergente (notificación breve y no interactiva) para informar que el índice se está compilando.

9

El índice recién creado aparece en la pestaña Atlas Search. Mientras se está construyendo el índice, el campo Status muestra Build in Progress. Cuando se termina de construir el índice, el campo Status muestra Active.

IMPORTANTE: Las colecciones más grandes tardan más tiempo en indexarse. Se recibirá una notificación por correo electrónico cuando el índice haya terminado de construirse.

10

Haz clic en el botón Query a la derecha del índice que deseas consultar.

11

Haz clic en Edit Query para ver una muestra de sintaxis de query por defecto en formato JSON.

12

La siguiente query busca en la Vista llamada listings_SearchableTypes house con un private room. Para ejecutar esta consulta, copie y pegue la consulta y haga clic en Search:

[
{
"$search": {
"index": "listingsSearchableTypes",
"compound": {
"should": [
{
"text": {
"path": "searchable_types.property_type",
"query": "House"
}
},
{
"text": {
"path": "searchable_types.room_type",
"query": "Private room"
}
}
]
}
}
}
]
SCORE: 2.0530142784118652 _id: "10051164"
name: "Catete's Colonial Big Hause Room B",
searchable_types: Object
property_type: 'House',
room_type: 'Private room',
bed_type: 'Real Bed'
SCORE: 2.0530142784118652 _id: "1016739"
name: 'Private Room (2) in Guest House at Coogee Beach',
searchable_types: Object
property_type: 'House',
room_type: 'Private room',
bed_type: 'Real Bed'
SCORE: 2.0530142784118652 _id: "10324377"
name: 'Suíte em local tranquilo e seguro',
searchable_types: Object
property_type: 'House',
room_type: 'Private room',
bed_type: 'Real Bed'
SCORE: 2.0530142784118652 _id: "1073607"
name: 'Bright Inner West Terrace Value+',
searchable_types: Object
property_type: 'House',
room_type: 'Private room',
bed_type: 'Real Bed'
SCORE: 2.0530142784118652 _id: "1077686"
name: 'BALAT',
searchable_types: Object
property_type: 'House',
room_type: 'Private room',
bed_type: 'Real Bed'
SCORE: 2.0530142784118652 _id: "10990260"
name: 'The Executive Posh Room',
searchable_types: Object
property_type: 'House',
room_type: 'Private room',
bed_type: 'Real Bed'
SCORE: 2.0530142784118652 _id: "10992286"
name: 'Holoholo Inn: Rain Forest (Priv-2)',
searchable_types: Object
property_type: 'House',
room_type: 'Private room',
bed_type: 'Real Bed'
SCORE: 2.0530142784118652 _id: "11396243"
name: 'Beautiful Ensuite Room -Easy access to city',
searchable_types: Object
property_type: 'House',
room_type: 'Private room',
bed_type: 'Real Bed'
SCORE: 2.0530142784118652 _id: "1145567"
name: 'ROOM + ENSUITE INNER CITY MOD HOUSE',
searchable_types: Object
property_type: 'House',
room_type: 'Private room',
bed_type: 'Real Bed'
SCORE: 2.0530142784118652 _id: "11464859"
name: 'The Sassy Lilac Megan Love Room',
searchable_types: Object
property_type: 'House',
room_type: 'Private room',
bed_type: 'Real Bed'
1

Para obtener más información, consulte Conectarse a un clúster a través de mongosh.

2
use sample_airbnb
3
db.createView(
"listings_SearchableTypes",
"listingsAndReviews",
[
{
"$set": {
"searchable_types": {
"$arrayToObject": {
"$filter": {
"input": { "$objectToArray": "$$ROOT" },
"cond": {
"$regexMatch": {
"input": "$$this.k",
"regex": /_type$/
}
}
}
}
}
}
}
]
)
4

La siguiente definición de índice en View llamada listingsSearchableTypes configura un typeSet para indexar automáticamente todos los campos en el documento searchable_types como el tipo string. Si agregas nuevos campos que coincidan con este patrón, MongoDB Search también indexará automáticamente esos campos.

db.listings_SearchableTypes.createSearchIndex(
"listingsSearchableTypes",
{
"analyzer": "lucene.standard",
"searchAnalyzer": "lucene.standard",
"mappings": {
"dynamic": false,
"fields": {
"searchable_types": [
{
"type": "document",
"dynamic": {
"typeSet": "tokenTypeSet"
}
}
]
}
},
"typeSets": [
{
"name": "tokenTypeSet",
"types": [
{
"type": "token"
}
]
}
]
}
)
5

Nota

El siguiente ejemplo consulta el índice listingsSearchableTypes ejecutando el comando .aggregate en la Vista denominada listings_SearchableTypes. Si tu clúster está ejecutando MongoDB v8.0, debes query la colección fuente (por ejemplo, listingsAndReviews) utilizando el índice en la Vista. Actualiza a MongoDB v8.1+ para query la Vista directamente.

La siguiente query busca en la vista llamada listings_SearchableTypes por house con un private room.

db.listings_SearchableTypes.aggregate([
{
"$search": {
"index": "listingsSearchableTypes",
"compound": {
"should": [
{
"equals": {
"path": "searchable_types.property_type",
"value": "House"
}
},
{
"equals": {
"path": "searchable_types.room_type",
"value": "Private room"
}
}
]
}
}
},
{
"$limit": 10
},
{
"$project": {
"_id": 0,
"searchable_types": 1,
"name": 1
}
}
])
[
{
name: "Catete's Colonial Big Hause Room B",
searchable_types: {
property_type: 'House',
room_type: 'Private room',
bed_type: 'Real Bed'
}
},
{
name: 'Private Room (2) in Guest House at Coogee Beach',
searchable_types: {
property_type: 'House',
room_type: 'Private room',
bed_type: 'Real Bed'
}
},
{
name: 'Suíte em local tranquilo e seguro',
searchable_types: {
property_type: 'House',
room_type: 'Private room',
bed_type: 'Real Bed'
}
},
{
name: 'Bright Inner West Terrace Value+',
searchable_types: {
property_type: 'House',
room_type: 'Private room',
bed_type: 'Real Bed'
}
},
{
name: 'BALAT',
searchable_types: {
property_type: 'House',
room_type: 'Private room',
bed_type: 'Real Bed'
}
},
{
name: 'The Executive Posh Room',
searchable_types: {
property_type: 'House',
room_type: 'Private room',
bed_type: 'Real Bed'
}
},
{
name: 'Holoholo Inn: Rain Forest (Priv-2)',
searchable_types: {
property_type: 'House',
room_type: 'Private room',
bed_type: 'Real Bed'
}
},
{
name: 'Beautiful Ensuite Room -Easy access to city',
searchable_types: {
property_type: 'House',
room_type: 'Private room',
bed_type: 'Real Bed'
}
},
{
name: 'ROOM + ENSUITE INNER CITY MOD HOUSE',
searchable_types: {
property_type: 'House',
room_type: 'Private room',
bed_type: 'Real Bed'
}
},
{
name: 'The Sassy Lilac Megan Love Room',
searchable_types: {
property_type: 'House',
room_type: 'Private room',
bed_type: 'Real Bed'
}
}
]

El siguiente ejemplo actualiza la vista movies_ReleasedAfter2000 de MongoDB para las películas anteriores a 2000.

db.runCommand(
{
collMod: "movies_ReleasedAfter2000",
viewOn: "movies",
"pipeline": [
{
$match: {
$expr: {
$lt: [
"$released",
ISODate("2000-01-01T00")
]
}
}
}
]
}
)

Después de ejecutar este comando, MongoDB Search detecta automáticamente el cambio en la definición de la Vista y realiza la reindexación sin tiempo de inactividad.

El siguiente ejemplo retorna las pipelines en la Vista movies_ReleasedAfter2000.

db.getCollectionInfos({ name: "movies_ReleasedAfter2000" })[0].options.pipeline
[
{
'$match': {
'$expr': { '$gt': [ '$released', ISODate('2000-01-01T00:00:00.000Z') ] }
}
}
]

Las transformaciones de vistas altamente complejas pueden aumentar el tiempo de indexación y query. Esto se debe a que el mongod debe leer la definición de vista cuando filtra y transforma las entradas del oplog durante la indexación (sincronización inicial y replicación en estado estable), y cuando aplica esas transformaciones a los documentos devueltos en tiempo de query.

Considera crear una vista materializada para evitar una carga extra de replicación en Atlas. También puedes query la colección de origen directamente para evitar la latencia de queries que se produce con la transformación de la vista.

Los índices cambian al estado FAILED en los siguientes escenarios:

  • Creas un índice en una vista que es incompatible con MongoDB Search.

  • Edita una vista de una manera que no cumple con los requisitos de compatibilidad de MongoDB Search.

  • Remover o cambiar la colección fuente de una vista.

    Por ejemplo, si se crea una vista sobre otra vista y se cambia la fuente de la vista superior a otra colección.

    Nota

    Esta limitación también se aplica si una Vista es descendiente de otras Vistas. Por ejemplo, no se puede cambiar o remover la colección de origen de la que provienen todos los descendientes.

Los índices cambian al estado STALE en los siguientes escenarios:

Advertencia

Si el pipeline de agregación definido en tu Vista es incompatible con los documentos de la colección, la replicación de búsqueda falla. Por ejemplo, si una expresión $toDouble opera sobre un campo del documento que contiene un arreglo, la replicación falla. Asegúrate de que tu Vista funcione con todos los documentos de la colección sin errores.

  • Si la definición de la vista provoca un fallo de agregación mientras un índice está READY, el índice se convierte en STALE. El índice volverá a READY después de que resuelvas el documento o cambies la definición de vista para que no falle más. Cuando STALE, el índice sigue siendo consultable. Si el índice se cae del oplog, se activa una reconstrucción del índice.

  • Si la definición de la Vista provoca un fallo en el pipeline de agregación mientras el índice es BUILDING, la creación de índices queda atascada hasta que soluciones el documento. El índice volverá a READY después de que resuelvas el documento o cambies la definición de vista para que no falle más.

Puedes ver los estados de los índices en la Interfaz de Usuario de Atlas en la página de Detalles del estado del índice.

Este error aparece cuando se hace una query a una vista usando una versión de MongoDB anterior a 8.1.

  • Si utiliza una versión de MongoDB anterior a la 8.0, le recomendamos que actualice a la 8.1+ para query la vista directamente. Puedes actualizar a 8.0 para query la colección de origen.

  • Si usas MongoDB 8.0, deberás query el índice de visualización en la colección de origen. Por ejemplo, ejecuta .aggregate() en la colección en lugar de en la vista.

Cuando se crea un índice de MongoDB Search en una vista, el proceso mongot realiza las mismas tareas que cuando se crea un índice de MongoDB Search en una colección normal. El proceso mongot:

  1. Crea índices de MongoDB Search basado en las reglas en la definición del índice para la colección.

  2. Supervisa los flujos de cambio para el estado actual de los documentos e índices de las colecciones para las que hayas definido los índices MongoDB Search.

  3. Procesa consultas de búsqueda de MongoDB Search y devuelve los IDs de los documentos y otros metadatos de búsqueda para los documentos coincidentes a mongod, que luego realiza una búsqueda completa de documentos y devuelve los resultados al cliente.

Cuando creas un índice de MongoDB Search en una vista, la definición de la vista se aplica durante el paso 1 y el 2, y los documentos transformados se indexan según la definición del índice de búsqueda, y luego se almacenan en disco.

Para obtener más información sobre las Vistas, consulte Vistas.

Para crear un índice de búsqueda vectorial de MongoDB en una Vista, consulta Usar Vistas con búsqueda vectorial de MongoDB.