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

7

我将在elasticsearch上构建一个Web应用程序。我想使用Java进行多重过滤。

Elasticsearch查询:

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

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

我希望能够过滤查询,使其可以使用两个不同的值(例如,“xyz”和“abc”)在同一字段collection上进行过滤。

目前,我已经编写了一个Java程序用于单个过滤器。

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

如何对同一字段的多个值进行查询过滤?

编辑:

实际上,在我的Web应用程序中,我已提取集合的值为:

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

集合是我的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。它说要为方法接收器添加转换。

2个回答

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

抱歉,我在提出问题时搞砸了。您能否请检查我的编辑部分? - Rose
运行正常。谢谢。由于缺少右括号而导致了一个错误。再次感谢。 - Rose

0

Term查询仅针对字段采用单个值,Terms查询针对字段采用多个值

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

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

强调文本 searchRequest.source(sourceBuilder);


如果不能硬编码数值,该怎么办?比如说有一个包含数值的集合。 - Stephane
可能会像 QueryBuilders.termsQuery("name", Arrays.asList(values)) 这样。 - Stephane

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接