Novedad en la versión 1.17.
Definición
MongoDB\Collection::createSearchIndexes()Cree uno o más índices de MongoDB Search o Vector Search para la colección.
function createSearchIndexes( array $indexes, array $options = [] ): string Este comando solo se puede ejecutar en una implementación alojada en MongoDB Atlas y requiere un nivel de clúster Atlas de al menos M10. Una implementación local de Atlas también puede usarse para el desarrollo.
Parámetros
$indexes: arregloArreglo de documentos que describen los índices que se deben crear.
Un campo de documento obligatorio
definitiondescribe el índice que se va a crear. Para obtener detalles sobre la sintaxis de definición, consulta Sintaxis de Definición de Índice de Búsqueda.Un campo de cadena
nameopcional especifica el nombre del índice de búsqueda que se va a crear. No se puede crear varios índices con el mismo nombre en una sola colección. Si no especifica un nombre, el nombre del índice por defecto esdefault.Un campo de string
typeopcional especifica el tipo de índice de búsqueda que se debe crear. Los valores aceptados son'search'y'vectorSearch'. Si no especificas un tipo, el método crea un índice de búsqueda en MongoDB Search.$options: arregloUn arreglo que especifica las opciones deseadas.
NombreTipoDescripcióncomment
mixto
Permite a los usuarios especificar un comentario arbitrario para ayudar a rastrear la operación a través del perfilador de bases de datos, la salida actualOp() y registros.
Return Values
Los nombres de los índices de MongoDB Search y Vector Search creados como un arreglo de strings.
Errores/Excepciones
MongoDB\Exception\UnsupportedException si se usan opciones que no sean compatibles con el servidor seleccionado (p. ej. collation, readConcern, writeConcern).
MongoDB\Exception\InvalidArgumentException por errores relacionados con el análisis de parámetros u opciones.
MongoDB\Driver\Exception\RuntimeException para otros errores a nivel de extensión (por ejemplo, errores de conexión).
Comportamiento
Los índices de MongoDB Search y Vector Search se gestionan de forma asíncrona. Después de crear o actualizar un índice, puedes ejecutar periódicamente y comprobar MongoDB\Collection::listSearchIndexes() el queryable campo de salida para determinar si está listo para usarse.
Ejemplos
Crear un índice con mapas dinámicos
El siguiente ejemplo crea un índice de búsqueda de MongoDB utilizando mapeos dinámicos para indexar todos los campos de documentos que contengan tipos de datos admitidos.
$collection = (new MongoDB\Client)->selectCollection('test', 'articles'); $indexNames = $collection->createSearchIndexes( [ [ 'name' => 'test-search-index', 'definition' => ['mappings' => ['dynamic' => true]], ], ] ); var_dump($indexNames);
La vista de salida se ilustraría como sigue:
array(1) { [0]=> string(17) "test-search-index" }
Ver también
Guía de Índices de búsqueda de MongoDB
Referencia del comando createSearchIndexes en el manual de MongoDB
MongoDB Search documentación en el Manual de MongoDB