Запрос Java Elastic Search дает неверные результаты - PullRequest
1 голос
/ 07 октября 2019

У меня проблема с запросомasticsearch в Java. Это мой код:

BoolQueryBuilder qb = QueryBuilders.boolQuery();

for example:
if (myFilter.getTerm1() != null) {
        qb.should(QueryBuilders.termsQuery("myfield1", myFilter.getTerm1()));
    }

if (myFilter.getTerm2() != null) {
        qb.should(QueryBuilders.termsQuery("myfield2", myFilter.getTerm2()));
    }

qb.minimumShouldMatch("100%");
SearchRequest request = op.searchRequest(classTarget(MyClass.class));// this just create a new SearchRequest    
sourceBuilder.query(QueryBuilders.simpleQueryStringQuery(qb.toString()));
    sourceBuilder.from((pageNumber));
    sourceBuilder.size(pageSize);
    request.source(sourceBuilder);

Проблема в том, что это возвращает мне все результаты, совпадающие с «myfield1 ИЛИ myfield2», Но мне нужно иметь все результаты, соответствующие« myfield1 AND myfield2 »

Например, если у меня есть 2 документа, один с

myfield1 =« Foo »и myfield2 = «Test»

и другие с:

myfield1 = «Elastic» и myfield2 = «Search»

, если я сделал запрос с myfield1 = «Foo»И myfield2 =« Поиск »Я ожидаю, что результатов не будет, но у меня есть оба документа.

Я также попытался использовать« должен »вместо« должен », и я попытался установить для оператора по умолчанию« И »”В sourceBuilder, но в этом случае у меня вообще нет результатов, даже если запрос должен что-то возвращать.

это печать" запроса "

Query request: SearchRequest{searchType=QUERY_THEN_FETCH, indices=[myIndex], indicesOptions=IndicesOptions[ignore_unavailable=false, allow_no_indices=true, expand_wildcards_open=true, expand_wildcards_closed=false, allow_aliases_to_multiple_indices=true, forbid_closed_indices=true, ignore_aliases=false], types=[data], routing='null', preference='data', requestCache=null, scroll=null, maxConcurrentShardRequests=0, batchedReduceSize=512, preFilterShardSize=128, allowPartialSearchResults=null, source={"from":0,"size":100,"query":{"simple_query_string":{"query":"{\n  \"bool\" : {\n    \"should\" : [\n      {\n        \"terms\" : {\n          \"myfield1.keyword\" : [\n            \"foo\"\n          ],\n          \"boost\" : 1.0\n        }\n      },\n      {\n        \"terms\" : {\n          \"myfield2.keyword\" : [\n            \"search\"\n          ],\n          \"boost\" : 1.0\n        }\n      }\n    ],\n    \"adjust_pure_negative\" : true,\n    \"minimum_should_match\" : \"100%\",\n    \"boost\" : 1.0\n  }\n}","flags":-1,"default_operator":"or","analyze_wildcard":false,"auto_generate_synonyms_phrase_query":true,"fuzzy_prefix_length":0,"fuzzy_max_expansions":50,"fuzzy_transpositions":true,"boost":1.0}}}}

1 Ответ

1 голос
/ 07 октября 2019

Если вам нужна логика AND, вы можете исключить should. Вместо этого вам нужно must и, вероятно, запрос match вместо term (так как я не думаю, что вам нужно точное соответствие). Попробуйте вместо этого:

if (myFilter.getTerm1() != null) {
    qb.must(QueryBuilders.matchQuery("myfield1", myFilter.getTerm1()));
}

if (myFilter.getTerm2() != null) {
    qb.must(QueryBuilders.matchQuery("myfield2", myFilter.getTerm2()));
}

также удалите qb.minimumShouldMatch("100%");

Также это QueryBuilders.simpleQueryStringQuery(qb.toString()) должно привести к ошибке, так как вы не можете сериализовать запрос bool в запрос simple_query_string, этопросто не предназначен для этой цели.

Просто измените ваше утверждение на следующее:

sourceBuilder.query(qb);

Если вы распечатаете свой запрос, вы увидите следующее, что, скорее всего, не то, что выхочу:

{
  "from": 0,
  "size": 100,
  "query": {
    "simple_query_string": {
      "query": "{\n  \"bool\" : {\n    \"should\" : [\n      {\n        \"terms\" : {\n          \"myfield1.keyword\" : [\n            \"foo\"\n          ],\n          \"boost\" : 1.0\n        }\n      },\n      {\n        \"terms\" : {\n          \"myfield2.keyword\" : [\n            \"search\"\n          ],\n          \"boost\" : 1.0\n        }\n      }\n    ],\n    \"adjust_pure_negative\" : true,\n    \"minimum_should_match\" : \"100%\",\n    \"boost\" : 1.0\n  }\n}",
      "flags": -1,
      "default_operator": "or",
      "analyze_wildcard": false,
      "auto_generate_synonyms_phrase_query": true,
      "fuzzy_prefix_length": 0,
      "fuzzy_max_expansions": 50,
      "fuzzy_transpositions": true,
      "boost": 1
    }
  }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...