MongoDB\Collection::createSearchIndexes()
1.17 版本中的新增功能。
定义
MongoDB\Collection::createSearchIndexes()
为collection创建一个或多个 Atlas Search 搜索索引。
function createSearchIndexes( array $indexes, array $options = [] ): string 此命令只能在托管在 MongoDB Atlas上的部署上运行,并且需要至少 M 10的 Atlas 集群层。 本地 Atlas 部署也可用于开发。
参数
$indexes
: array描述要创建的索引的文档数组。
必填的
definition
文档字段描述了要创建的索引。 有关定义语法的详细信息,请参阅Atlas Search索引定义语法。可选的
name
字符串字段指定要创建的搜索索引的名称。 不能在单个collection上创建多个同名索引。如果不指定名称,则索引名为“default”。$options
: array指定所需选项的数组。
Return Values
以字符串数组形式表示的已创建 Atlas Search 索引的名称。
错误/异常
MongoDB\Exception\UnsupportedException
,如果所选服务器使用了选项但不支持选项(例如collation
、readConcern
、writeConcern
)。
MongoDB\Exception\InvalidArgumentException
用于与参数或选项解析相关的错误。
MongoDB\ 驱动程序\Exception\RuntimeException 对于扩展级别的其他错误(例如连接错误)。
行为
Atlas Search索引是异步托管的。 创建或更新索引后,您可以定期执行MongoDB\Collection::listSearchIndexes()
并检查queryable
输出字段,以确定是否可以使用。
示例
使用动态映射创建索引
以下示例使用动态映射创建 Atlas Search 索引,为包含受支持数据类型的所有文档字段编制索引。
$collection = (new MongoDB\Client)->selectCollection('test', 'articles'); $indexNames = $collection->createSearchIndexes( [ [ 'name' => 'test-search-index', 'definition' => ['mappings' => ['dynamic' => true]], ], ] ); var_dump($indexNames);
而输出将类似如下所示:
array(1) { [0]=> string(17) "test-search-index" }