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

时间:2016-06-27 20:19:43

标签: elasticsearch elasticsearch-java-api

我在elasticsearch之上构建了一个Web应用程序。我想用Java做一个多重过滤器。

Elasticsearch查询:

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

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

我想过滤查询,以便它应该在具有两个不同值的相同字段collection上进行过滤(例如,&#34; xyz&#34;和&#34; abc&#34;)< / p>

现在,我已为单个过滤器编写了一个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(值:true),Collection[1]是usa_collection(值: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。它说添加转换为方法接收器。

2 个答案:

答案 0 :(得分:4)

您可以使用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"));

答案 1 :(得分:0)

条款查询将仅针对一个字段,条款查询将针对多个字段

SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();
BoolQueryBuilder QueryBuilders = QueryBuilders.boolQuery();

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

强文本 searchRequest.source(sourceBuilder);