找出自定义分数脚本中的字段匹配项

时间:2013-02-28 22:20:56

标签: java scala elasticsearch

我正在使用带有multiMatchQuery的自定义分数查询。最终我想要的是简单的,并且几乎不需要解释。在我的Java自定义分数脚本中,我希望能够找出与之匹配的字段。

示例:

如果我搜索星巴克并且结果返回时名为星巴克,那么我希望能够知道name.basic是与我的查询匹配的字段。如果我搜索咖啡并且星巴克回来了,我希望能够知道标签是匹配的字段。

有没有这样做?

搜索查询代码:

def basicSearchableSearch(t: String, lat: Double, lon: Double, r: Double, z: Int, bb: BoundingBox, max: Int): SearchResponse = {
    val multiQuery = filteredQuery(
      multiMatchQuery(t)
        //Matches businesses and POIs
        .field("name.basic").operator(Operator.OR)
                .field("name.no_space")
                //Businesses only
        .field("tags").boost(6f), 
      geoBoundingBoxFilter("location")
        .bottomRight(bb.botRight.y,bb.botRight.x)
        .topLeft(bb.topLeft.y,bb.topLeft.x)
    )

    val customQuery = customScoreQuery(
      multiQuery
    )
    .script("customJavaScript")
    .lang("native")
    .param("lat",lat)
    .param("lon",lon)
    .param("zoom",z)

    global.Global.getClient().prepareSearch("searchable")
      .setSearchType(SearchType.DFS_QUERY_THEN_FETCH)
      .setQuery(customQuery)
      .setFrom(0).setSize(max)
      .execute()
      .actionGet();
  }

1 个答案:

答案 0 :(得分:1)

这对于简单查询来说很简单。在复杂查询中,哪个字段匹配的问题实际上非常重要。所以,我想不出任何有效的方法。

也许,您可以考虑将自定义分数计算更接近匹配。 multi_match查询基本上是由match查询组合的同一查询字符串上的一组dis_max查询的快捷方式。所以,你目前正在构建这样的东西:

custom_score(
    filtered(
        dis_max(match_1, match_2, match_3)
    )
)

你可以做的是在dis_max下移动你的custom_score并构建如下:

filtered(
    dis_max(
        custom_score_1(match_1),
        custom_score_2(match_2),
        custom_score_3(match_3)
    )
)

显然,这将是一个稍微不同的查询,因为dis_max将对自定义分数而不是原始分数进行操作。