Índices de pesquisa do Atlas
Nesta página
Visão geral
Neste guia, você pode aprender como gerenciar programaticamente seus índices Atlas Search e Atlas Vector Search usando a biblioteca PHP.
O recurso Atlas Search permite realizar pesquisas de texto completo em collections hospedadas no MongoDB Atlas. Para saber mais sobre o Atlas Search, consulte a Visão geral do Atlas Search .
O Atlas Vector Search permite realizar pesquisas semânticas em incorporações vetoriais armazenadas no MongoDB Atlas. Para saber mais sobre o Atlas Vector Search, consulte a Visão geral do Atlas Vector Search .
Você pode utilizar os seguintes métodos em uma instância do MongoDB\Collection
para gerenciar seus índices do Atlas Search e Vector Search :
MongoDB\Collection::createSearchIndex()
MongoDB\Collection::createSearchIndexes()
MongoDB\Collection::listSearchIndexes()
MongoDB\Collection::updateSearchIndex()
MongoDB\Collection::dropSearchIndex()
Observação
O gerenciamento do índice do Atlas Search e do Vector Search é assíncrono
A Biblioteca PHP do MongoDB gerencia índices do Atlas Search e Vector Search de forma assíncrona. Os métodos da biblioteca descritos nas seções a seguir retornam a resposta do servidor imediatamente, mas as alterações nos índices de pesquisa ocorrem em segundo plano e podem não ser concluídas até algum tempo depois.
As seções a seguir fornecem exemplos de código que demonstram como usar cada um dos métodos anteriores.
Criar um índice de pesquisa
Você pode usar o método createSearchIndex()
para criar um único índice do Atlas Search ou Vector Search em uma collection ou o método createSearchIndexes()
para criar vários índices simultaneamente.
O seguinte exemplo de código mostra como criar um único índice do Atlas Search:
$searchIndexName = $collection->createSearchIndex( ['mappings' => ['dynamic' => true]], ['name' => 'mySearchIdx'] );
O seguinte exemplo de código mostra como criar um único índice do Atlas Vector Search :
$vectorSearchIndexName = $collection->createSearchIndex( [ 'fields' => [[ 'type' => 'vector', 'path' => 'plot_embedding', 'numDimensions' => 1536, 'similarity' => 'dotProduct' ]] ], ['name' => 'myVSidx', 'type' => 'vectorSearch'] );
O exemplo de código a seguir mostra como criar índices Atlas Search e Vector Search em uma chamada:
$indexNames = $collection->createSearchIndexes( [ [ 'name' => 'SearchIdx', 'definition' => ['mappings' => ['dynamic' => true]], ], [ 'name' => 'VSidx', 'type' => 'vectorSearch', 'definition' => [ 'fields' => [[ 'type' => 'vector', 'path' => 'plot_embedding', 'numDimensions' => 1536, 'similarity' => 'dotProduct' ]] ], ], ] );
Depois de criar índices do Atlas Search ou Atlas Vector Search , você pode executar os tipos de query correspondentes em seus documentos. Para saber mais, consulte os seguintes guias:
Atlas Search guide
Listar índices de pesquisa
Você pode utilizar o método listSearchIndexes()
para retornar uma array dos índices Atlas Search e Vector Search em uma coleção:
foreach ($collection->listSearchIndexes() as $indexInfo) { echo json_encode($indexInfo), PHP_EOL; }
Atualizar um Índice de Pesquisa
Você pode utilizar o método updateSearchIndex()
para atualizar um índice do Atlas Search ou Vector Search . Você pode usar este método para alterar o nome ou a configuração de um índice existente.
O seguinte código mostra como atualizar um índice de pesquisa para usar um analisador simples no campo title
:
$collection->updateSearchIndex( 'mySearchIdx', ['mappings' => [ 'dynamic' => false, 'fields' => [ 'title' => [ 'type' => 'string', 'analyzer' => 'lucene.simple' ] ] ]] );
Excluir um índice de pesquisa
Você pode usar o método dropSearchIndex()
para remover um índice do Atlas Search ou Vector Search de uma coleção.
O código a seguir mostra como excluir o índice do Atlas Search chamado mySearchIdx
:
$collection->dropSearchIndex('mySearchIdx');
Informações adicionais
Para exibir exemplos executáveis que demonstram como gerenciar índices, consulte Otimizar queries usando índices.
Para visualizar tutoriais que explicam como usar o recurso Atlas Search, consulte Comece a usar o Atlas Search na documentação do Atlas .
Documentação da API
Para saber mais sobre qualquer um dos métodos discutidos nesta guia, consulte a seguinte documentação da API: