🔥码云GVP开源项目 12k star Uniapp+ElementUI 功能强大 支持多语言、二开方便! 广告
# Suggesters 原文链接 : [https://www.elastic.co/guide/en/elasticsearch/reference/5.0/search-suggesters.html](https://www.elastic.co/guide/en/elasticsearch/reference/5.0/search-suggesters.html) 译文链接 : [http://www.apache.wiki/display/Elasticsearch/Suggesters](http://www.apache.wiki/display/Elasticsearch/Suggesters) 贡献者 : @Josh **suggest** 特征通过使用 **suggester** 基于所提供的文本来建议相似的术语。部分 **suggest** 功能还在开发中。 **suggest** 请求部分在 **_search** 请求中或者通过 **REST****_suggest** 断点和查询部分一起定义。 ``` POST twitter/_search { "query" : { "match": { "message": "tring out Elasticsearch" } }, "suggest" : { "my-suggestion" : { "text" : "trying out Elasticsearch", "term" : { "field" : "message" } } } } ``` 针对**_suggest** 端点执行的建议请求应忽略周围的 **suggest** 元素,该元素仅在 **suggest** 请求是搜索的一部分时使用。 ``` POST _suggest { "my-suggestion" : { "text" : "tring out Elasticsearch", "term" : { "field" : "message" } } } ``` 每个请求可以指定几个 **suggestions** 。 每个 **suggestion** 用任意名称标识。 在下面的示例中,请求了两个 **suggestions** 。 **my-suggest-1** 和 **my-suggest-2** 两个 **suggestions** 使用术语 **suggester**,但有不同的 **test** 。 ``` POST _suggest { "my-suggest-1" : { "text" : "tring out Elasticsearch", "term" : { "field" : "message" } }, "my-suggest-2" : { "text" : "kmichy", "term" : { "field" : "user" } } } ``` 下面的 **suggest** 响应示例包括对于 **my-suggest-1** 和 **my-suggestion-2** 的 **suggest** 响应。 每个**suggest** 部分包含条目(**entries**)。 每个条目实际上是来自 **suggest** 文本的 **token** ,并且包含 **suggest** 文本中的 **suggest** 条目文本,原始的条目开始于 **suggest** 偏移(**offset**)和长度,并且如果找到任意数目的选项。 ``` { "_shards": ... "my-suggest-1": [ { "text": "tring", "offset": 0, "length": 5, "options": [ {"text": "trying", "score": 0.8, "freq": 1 } ] }, { "text": "out", "offset": 6, "length": 3, "options": [] }, { "text": "elasticsearch", "offset": 10, "length": 13, "options": [] } ], "my-suggest-2": ... } ``` 每个选项数组(**option array**)包含一个选项对象,其中包括 **suggest** 文本,其文档频率和分数与 **suggest** 输入文本相比较。 分数的意义取决于使用的**suggester**。 术语 **suggester** 的分数是基于编辑(edit)距离。 全局 **suggest** 文本 为了避免重复 **suggest** 文本,可以定义全局文本。 在下面的示例中,**suggest** 文本是全局定义的,并适用于 **my-suggest-1** 和 **my-suggest-2** 建议。 ``` POST _suggest { "text" : "tring out Elasticsearch", "my-suggest-1" : { "term" : { "field" : "message" } }, "my-suggest-2" : { "term" : { "field" : "user" } } } ``` 在上述示例中,**suggest** 文本也可以被指定为 **suggest** 特定选项。 在 **suggestion** 级别上指定的 **suggest** 文本覆盖全局级别上的 **suggest** 文本。