Elasticsearch完成 - 按分数返回前10个文档

时间:2015-03-12 13:41:06

标签: java autocomplete elasticsearch autosuggest

我使用Elasticsearch和自动填充的完成类型。 对于空搜索,我想在整个映射中返回前十个文档(按分数)。

我的映射是这样创建的:

String type = AutoCompleteServiceImpl.AC_TYPE;

XContentBuilder mapping = jsonBuilder()
        .startObject()
          .startObject(type)
            .startObject("properties")
              .startObject(AutoCompleteServiceImpl.AC_FIELD)
                .field("type", "completion")
              .endObject()
            .endObject()
          .endObject()
        .endObject();

PutMappingResponse mappingResponse = 
  client.admin().indices().preparePutMapping(index)
  .setType(type).setSource(mapping)
  .execute().actionGet();

AC_FIELD =" keyword_suggest"。

我通过以下方式添加文件:

XContentBuilder json =  jsonBuilder()
        .startObject()
          .startObject(AC_FIELD)
            .array("input", record.getInput().toArray(new String[1]))
            .field("output", record.getOutput())
            .field("weight", record.getWeight())
          .endObject()
        .endObject();

elasticsearch.getClient()
    .prepareIndex(elasticsearch.getIndexName(), AC_TYPE, record.getId())
    .setSource(json)
    .execute().actionGet();

当用户输入文字(searchTermLC)时,我使用建议来电,而不是搜索(Completion Suggesters)。我称之为:

CompletionSuggestionBuilder suggestionsBuilder = new CompletionSuggestionBuilder(AC_TYPE);
suggestionsBuilder.field(AC_FIELD);
suggestionsBuilder.text(searchTermLC);
if (limit != null)
  suggestionsBuilder.size(limit);

SuggestResponse response =  
      elasticsearch.getClient()
        .prepareSuggest(elasticsearch.getIndexName())
        .addSuggestion(suggestionsBuilder)
        .execute().actionGet();

这适用于带有文字的建议,但不适用于空白建议。

在我的尝试中,我尝试过:

  • 为searchTermLC分配一个空字符串(""),但返回no 选项。
  • 不提供建议的文字,但是会抛出一个 响应中的NullPointerException。
  • 使用搜索而不是建议,但由于权重不是映射的字段之一,我无法按其排序(错误:"找不到[keyword_suggest.weight]的映射,以便排序")。默认排序在输出上按字母顺序排列。

我希望完成映射中所有文档的前10个结果按其分数排序。

1 个答案:

答案 0 :(得分:0)

由于您只有一个空字符串,因此无法为完成建议器计算得分。在这种情况下得分确实没有意义。

根据重量匹配所有文件和排序,您可以根据重量获得十个最高的文件。

POST my_type/_search
{
    "sort":{"suggest_field_name.weight": {"order": "desc"}}
}

由于输入字段为空时结果可能始终相同,因此您可以在应用程序中缓存顶部结果。