我现在就是这样做的:
..
.setQuery(
filteredQuery(
multiMatchQuery(String.format("*%s*", query), "name", "address", "phone")
.type(MultiMatchQueryBuilder.Type.CROSS_FIELDS),
geoDistanceFilter("location")
.distance(radius, DistanceUnit.KILOMETERS)
.geoDistance(GeoDistance.PLANE)
.point(latitude, longitude)
)
)
..
问题是,即使使用通配符,它也不会搜索部分短语或部分单词..
我找到了matchPhraseQuery
,但它似乎只适用于一个字段..有没有其他方法可以实现此类搜索?
答案 0 :(得分:1)
不幸的是,多匹配不支持查询通配符。而不是使用multimatch,听起来你可能想看看Query String Query,它具有更多的模式匹配灵活性,并且可以针对多个字段运行。查询字符串非常强大,因为它为您提供了Lucene查询语言供您使用。它的DSL看起来像:
{
"query_string" : {
"fields" : ["name", "address", "phone"],
"query" : "*query*"
}
}
而在Java中,有以下几点:
..
.setQuery(
filteredQuery(
.queryString("*test*").field("name").field("phone").field("address"),
geoDistanceFilter("location")
.distance(radius, DistanceUnit.KILOMETERS)
.geoDistance(GeoDistance.PLANE)
.point(latitude, longitude)
)
)
..
搜索时的通配符和模式匹配气馁,因为它们的计算成本很高。您应该尝试查看这些模糊搜索案例的索引时间解决方案,使用NGram Tokenizer之类的东西在必填字段上生成这些部分匹配。使用不同类型的分析器来获得更好的搜索索引,而不是试图根据您的意愿弯曲查询构建器。