Elasticsearch java api 或过滤器

Elasticsearch java api or filter

我需要应用一个 "OR" 过滤器,这相当于 ('a' or 'b' or 'c' or 'd' or 'e') 下面提供了等效的 ES 查询

"query_string": {
                      "query": "category: (\"a\", \"b\", \"c\", \"d\", \"e\")"
                   }

我有下面提到的 JAVA ES API 代码,我对在 Java 中添加 OR 过滤器感到震惊。有人可以帮忙吗?

SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder()
     searchSourceBuilder.query(QueryBuilders.boolQuery()
                .must(QueryBuilders.filteredQuery(QueryBuilders.matchAllQuery(),
                        FilterBuilders.termFilter("category","a")))
                .must(QueryBuilders.rangeQuery("@timestamp").from(fromHr).to(toHr)))
                .fields(fieldList);

根据您的示例,我假设您使用的是 ES 1.x 并假设 RangeQuery 应该是一个查询。如果我正确理解你的问题,你想做这样的事情:

QueryBuilders.filteredQuery(
 QueryBuilders.rangeQuery("@timestamp").from(fromHr).to(toHr),
 FilterBuilders.boolFilter()
  .should(FilterBuilders.termFilter("category","a"))
  .should(FilterBuilders.termFilter("category","b")) 
  .should(FilterBuilders.termFilter("category","c")) 
  .should(FilterBuilders.termFilter("category","d"))   
  .should(FilterBuilders.termFilter("category","e"))
)

不过,您也可以使用 terms filter:

QueryBuilders.filteredQuery(
  QueryBuilders.rangeQuery("@timestamp").from(fromHr).to(toHr),
  FilterBuilders.termsFilter("category", "a", "b", "c", "d", "e", "f" ))