Docs 菜单
Docs 主页
/ / /
PHP 库手册
/ /

MongoDB\Collection::createSearchIndex()

在此页面上

  • 定义
  • 参数
  • Return Values
  • 错误/异常
  • 行为
  • 示例
  • 另请参阅

1.17 版本中的新增功能

MongoDB\Collection::createSearchIndex()

为collection创建 Atlas Search 搜索索引。

function createSearchIndex(
array|object $definition,
array $options = []
): string

此命令只能在托管在 MongoDB Atlas上的部署上运行,并且需要至少 M 10的 Atlas 集群层。 本地 Atlas 部署也可用于开发。

$definition : array|object
描述要创建的索引的文档。 有关定义语法的详细信息,请参阅搜索索引定义事务语法。
$options : array

指定所需选项的数组。

名称
类型
说明
comment
混合

使用户可以指定任意注释来帮助通过数据库分析器currentOp 输出和日志来跟踪操作。

名称
字符串

要创建的搜索索引的名称。

不能在单个collection上创建多个同名索引。如果不指定名称,则索引名为“default”。

以字符串形式表示的已创建 Atlas Search 索引的名称。

MongoDB\Exception\UnsupportedException,如果所选服务器使用了选项但不支持选项(例如collationreadConcernwriteConcern)。

MongoDB\Exception\InvalidArgumentException 用于与参数或选项解析相关的错误。

MongoDB\ 驱动程序\Exception\RuntimeException 对于扩展级别的其他错误(例如连接错误)。

Atlas Search索引是异步托管的。 创建或更新索引后,您可以定期执行MongoDB\Collection::listSearchIndexes()并检查queryable输出字段,以确定是否可以使用。

以下示例使用动态映射创建 Atlas Search 索引,为包含受支持数据类型的所有文档字段编制索引。

<?php
$collection = (new MongoDB\Client)->selectCollection('test', 'articles');
$indexName = $collection->createSearchIndex(
['mappings' => ['dynamic' => true]],
['name' => 'test-search-index']
);
var_dump($indexName);

而输出将类似如下所示:

string(17) "test-search-index"

后退

createIndexes()