首页 > 解决方案 > 如何使用java在elasticsearch中与多个setQuery?

问题描述

我正在尝试使用 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();

我在这里做错了什么?

标签: javaspring-bootelasticsearch

解决方案


你有两个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();

推荐阅读