多个字段的词组匹配

时间:2015-07-13 17:03:55

标签: java elasticsearch elasticsearch-java-api

我现在就是这样做的:

.. .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,但它似乎只适用于一个字段..有没有其他方法可以实现此类搜索?

1 个答案:

答案 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之类的东西在必填字段上生成这些部分匹配。使用不同类型的分析器来获得更好的搜索索引,而不是试图根据您的意愿弯曲查询构建器。