如何使用 Java 在 Elasticsearch 中进行多过滤器查询?

How to do multiple filter query in Elasticsearch using Java?

我已经在 elasticsearch 之上构建了一个网络应用程序。我想使用 Java 进行多重过滤。

弹性搜索查询:

{
  "query": {
    "bool": {
      "must": [
        {"match": {
          "T": "TEXT"},
          "match": {
            "new_content": "TEXT"
          }
        },

      ],
      "filter": {
        "term": {
          "collection1": "xyz"
        },
        "term": {
          "collection2": "abc"
        }

我想过滤查询,以便它应该过滤具有两个不同值的同一字段 collection(例如,"xyz" 和 "abc")

现在,我已经为单个过滤器编写了一个 Java 程序。

BoolQueryBuilder boolQuery = QueryBuilders.boolQuery()
                .must(QueryBuilders.simpleQueryStringQuery(query).field("newContent").field("T"))
                .filter(QueryBuilders.termQuery(Collection1, "abc"));

我应该如何为多个值过滤同一字段的查询?

编辑

实际上在我的网络应用程序中,我提取了集合的值:

String[] Collection=request.getParameterValues("site");

Collection 是我elasticsearch 文档中的字段。假设 Collection[0] 是 germany_collection(value:true),Collection[1] 是 usa_collection(value:true)。我想编写一个查询来过滤我的文档,以便在 germany_collection:true 和 usa_collection:true 时得到结果。

这是我的原程序:

public StringBuffer getJson(String query, String start, String [] Collection{
Client client = TransportClient.builder().build()
                .addTransportAddress(new InetSocketTransportAddress(InetAddress.getByName("127.0.0.1"), 9300));

        BoolQueryBuilder boolQuery = QueryBuilders.boolQuery()
                .must(QueryBuilders.simpleQueryStringQuery(query).field("newContent").field("T"))
                .filter(QueryBuilders.termQuery(Collection[0], "true").filter(QueryBuilders.termQuery(Collection[1], "true");

但是当我应用这个过滤器时,我收到了这个错误 The method filter(TermsQueryBuilder) is undefined for the type TermsQueryBuilder。它说向方法接收器添加强制转换。

您可以使用 terms 查询而不是多个 term 查询:

BoolQueryBuilder boolQuery = QueryBuilders.boolQuery()
                .must(QueryBuilders.simpleQueryStringQuery(query).field("newContent").field("T"))
                .filter(QueryBuilders.termsQuery(Collection, "abc", "xyz"));
                                          ^                    ^      ^
                                          |                    |      |
                                    use termsQuery      with multiple values

更新

我很惊讶你的代码完全可以编译,因为你缺少一些右括号,只需像这样重写你的查询,它应该可以工作:

    BoolQueryBuilder boolQuery = QueryBuilders.boolQuery()
            .must(QueryBuilders.simpleQueryStringQuery(query).field("newContent").field("T"))
            .filter(QueryBuilders.termQuery(Collection[0], "true"))
            .filter(QueryBuilders.termQuery(Collection[1], "true"));

Term 查询将只为 filed 取一个值,Terms 查询将为 filed

取多个值
SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();
BoolQueryBuilder QueryBuilders = QueryBuilders.boolQuery();

sourceBuilder.query(QueryBuilders.filter(QueryBuilders.termsQuery("age", "44", "45", "30")));

强文本 searchRequest.source(sourceBuilder);