我正在尝试使用elasticsearch为搜索过滤器创建查询。我创建了一个查询,该查询根据搜索字词,价格范围和品牌列表显示结果。搜索字词和价格范围显示的结果正确,但是当提供品牌列表时,将显示与所选品牌有关的所有结果。
我想要搜索字词AND价格AND品牌的结果
这是我的查询
BoolQueryBuilder query = QueryBuilders.boolQuery();
for (String key : brands) {
query.must(QueryBuilders.matchQuery("brand", key));
}
SearchResponse searchresponse = client
.prepareSearch("product")
.setTypes("product")
.setQuery(
QueryBuilders.matchPhraseQuery("name", pSearchTerm))
.setPostFilter(
QueryBuilders.rangeQuery("unit_price").from(min)
.to(max))
.setQuery(query).setExplain(true)
.execute().actionGet();
我在这里做什么错了?
答案 0 :(得分:3)
您有两个setQuery()
通话,因此第二个通话将覆盖第一个通话。您需要将所有约束组合到一个查询中,如下所示:
// brand list
BoolQueryBuilder query = QueryBuilders.boolQuery();
for (String key : brands) {
query.must(QueryBuilders.matchQuery("brand", key));
}
// search term
query.must(QueryBuilders.matchPhraseQuery("name", pSearchTerm));
// price range
query.filter(QueryBuilders.rangeQuery("unit_price").from(min).to(max));
SearchResponse searchresponse = client
.prepareSearch("product")
.setTypes("product")
.setQuery(query)
.setExplain(true)
.execute().actionGet();