我正在使用带有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();
}
答案 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
将对自定义分数而不是原始分数进行操作。