New in version 1.17.
Definition
- MongoDB\Collection::createSearchIndexes()
- Create one or more Atlas Search or Vector Search indexes for the collection. - function createSearchIndexes( - array $indexes, - array $options = [] - ): string - This command can only be run on a deployment hosted on MongoDB Atlas and requires an Atlas cluster tier of at least M10. A Local Atlas Deployment can also be used for development. 
Parameters
- $indexes: array
- Array of documents describing the indexes to create. - A required - definitiondocument field describes the index to create. For details on definition syntax, see Search Index Definition Syntax.- An optional - namestring field specifies the name of the search index to create. You cannot create multiple indexes with the same name on a single collection. If you do not specify a name, the default index name is- default.- An optional - typestring field specifies the type of search index to create. Accepted values are- 'search'and- 'vectorSearch'. If you do not specify a type, the method creates an Atlas Search index.
- $options: array
- An array specifying the desired options. NameTypeDescription- comment - mixed - Enables users to specify an arbitrary comment to help trace the operation through the database profiler, currentOp output, and logs. 
Return Values
The names of the created Atlas Search and Vector Search indexes as an array of strings.
Errors/Exceptions
MongoDB\Exception\UnsupportedException if options are used and
not supported by the selected server (e.g. collation, readConcern,
writeConcern).
MongoDB\Exception\InvalidArgumentException for errors related to
the parsing of parameters or options.
MongoDB\Driver\Exception\RuntimeException for other errors at the extension level (e.g. connection errors).
Behavior
Atlas Search and Vector Search indexes are managed asynchronously. After creating or updating an
index, you can periodically execute
MongoDB\Collection::listSearchIndexes() and check the
queryable output field
to determine whether it is ready to be used.
Examples
Create an Index with Dynamic Mappings
The following example creates an Atlas Search index using dynamic mappings to index all document fields containing supported data types.
$collection = (new MongoDB\Client)->getCollection('test', 'articles'); $indexNames = $collection->createSearchIndexes(     [         [             'name' => 'test-search-index',             'definition' => ['mappings' => ['dynamic' => true]],         ],     ] ); var_dump($indexNames); 
The output would then resemble:
array(1) {   [0]=>   string(17) "test-search-index" } 
See Also
- Atlas Search Indexes guide 
- createSearchIndexes command reference in the MongoDB manual 
- Atlas Search documentation in the MongoDB Manual