如何在分面搜索时对字符串字段进行索引
您可以使用Atlas SearchstringFacet
类型为 字符串字段索引以进行分面,这样您就可以对该字段运行 分面(Facet)查询。 Atlas Search在为分面索引string
字段时不应用分析器。
Atlas Search 仅支持对索引为stringFacet
类型的字段进行分面(Facet)查询。要对同一字段也执行普通搜索,您也必须将该字段作为string
类型进行索引。
要对嵌入式文档中的 string 字段进行分面,您必须将父字段作为文档类型进行索引。当您在嵌入式文档中对字符串字段进行分面时,Atlas Search 只返回与父文档数量匹配的分面计数。
Atlas Search 不会动态索引 string
值已进行分面。您必须使用静态映射来索引 string
值以进行分面。您可以使用 Atlas UI 中的可视化编辑器或 JSON 编辑器将 string
字段编制索引为 number
类型。
为 stringFacet
类型定义索引
要定义 stringFacet
类型的索引,请在 Atlas UI 中选择您的首选配置方法,然后选择数据库和集合。
单击 Refine Your Index 配置索引。
在 Field Mappings 部分中,单击 Add Field Mapping 打开 Add Field Mapping 窗口。
单击 Customized Configuration(连接)。
从 Field Name 下拉菜单中选择要索引的字段。
注意
您无法对字段名称开头包含美元 (
$
) 符号的字段创建索引。单击Data Type下拉列表并选择StringFacet 。 要了解有关此类型的更多信息,请参阅字段属性。
单击 Add(连接)。
以下是 stringFacet
类型的 JSON 语法。将默认索引定义替换为以下内容。要了解有关字段的更多信息,请参阅字段属性。
{ "mappings": { "dynamic": true|false, "fields": { "<field-name>": { "type": "stringFacet" } } } }
配置 stringFacet
类型的属性
Atlas Search stringFacet
类型采用以下参数:
用户界面字段名称 | JSON Option | 类型 | 必要性 | 说明 |
---|---|---|---|---|
Data Type |
| 字符串 | 必需 | 标识此字段类型的可读标签。值必须是 |
尝试 stringFacet
类型的示例
以下索引定义示例使用 sample_mflix.movies 集合。如果您的集群上已加载示例数据,则可以使用 Atlas 用户界面中的可视化编辑器或 JSON 编辑器来配置索引。选择首选配置方法后,选择数据库和集合并优化索引以添加字段映射。
样本数据集中sample_mflix.movies
collection的以下索引定义将genres
字段索引为stringFacet
以进行分面(Facet)。
在 Add Field Mapping 窗口中,从 Field Name 下拉列表中选择 genres。
单击 Data Type(添加数据)下拉列表并选择 StringFacet(插入文档)。
单击 Add(连接)。
{ "mappings": { "dynamic": false, "fields": { "genres": { "type": "stringFacet" } } } }
示例数据集中 sample_mflix.movies
集合的以下索引定义将 genres
字段索引为 stringFacet
和 string
类型,从而为查询返回以下类型的结果:
在 Add Field Mapping 窗口中,从 Field Name 下拉列表中选择 genres。
单击 Data Type(添加数据)下拉列表并选择 StringFacet(插入文档)。
单击 Add(连接)。
重复步骤 1,并从 Data Type 下拉列表中选择 String。
查看 String Properties 的默认设置,然后单击 Add。
{ "mappings": { "dynamic": false, "fields": { "genres": [ { "type": "stringFacet" }, { "type": "string" } ] } } }
了解详情
要学习;了解有关 facet
收集器的详情并查看示例查询,请参阅示例。
要学习;了解如何使用分面(Facet)定义创建索引并使用 facet
收集器查询该索引,请参阅如何在Atlas Search中使用分面教程。
要查看使用 stringFacet
对分页结果运行分面搜索的示例索引和查询,请参阅对分页结果使用分面。