ElasticSearch Nested Query не возвращает данные - PullRequest
0 голосов
/ 22 февраля 2019

У меня есть индекс в ElasticSearch (клиенты), который имеет следующее частичное сопоставление:

      "addresses": {
          "type": "nested",
          "properties": {
              "address": {
                  "type": "keyword"
              },
              "phone": {
                  "type": "keyword"
              }
          }
      },

Я пытаюсь найти конкретный адрес (назовем его «foo street»).Я использую ElasticSearch 6.3.и RestHighLevelClient (6.3).

В моем случае следующие переменные имеют следующие значения:

docName = "addresses"
name = "address"
value = "foo street"

Я знаю, что хотя бы один из документов в моем индексе клиентов имеет адресиз "foo street"

Мой код для создания NestedQueryBuilder таков:

QueryBuilder innerQuery = QueryBuilders.matchQuery(name, value);
NestedQueryBuilder nestedQueryBuilder = QueryBuilders.nestedQuery(
    docName, innerQuery, ScoreNode.None);

SearchRequest request = new SearcRequest("customers");
SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
searchSourceBuilder.query(nestedQueryBuilder);
searchSourceBuilder.from(from);
searchSourceBuilder.size(size);
request.source(searchSourceBuilder);

Если я регистрирую свой объект NestedQueryBuilder (вызывая toString (), это то, что я получаю:

{
"nested" : {
  "query" : {
    "match" : {
      "ip_address" : {
        "query" : "10.214.159.193",
        "operator" : "OR",
        "prefix_length" : 0,
        "max_expansions" : 50,
        "fuzzy_transpositions" : true,
        "lenient" : false,
        "zero_terms_query" : "NONE",
        "auto_generate_synonyms_phrase_query" : true,
        "boost" : 1.0
      }
    }
  },
  "path" : "links",
  "ignore_unmapped" : false,
  "score_mode" : "none",
  "boost" : 1.0
}
}

Почему я не получаю хиты?

Ниже приведено значение в SearchResponse:

Status: OK
Took: 0s
terminatedEarly: null
timedOut: false
total hits: 0
maxScore: NaN

1 Ответ

0 голосов
/ 22 февраля 2019

Вы должны использовать полное имя для вложенных полей.Используйте links.ip_address вместо ip_address.

Ваш запрос должен быть следующим:

{
  "nested": {
    "query": {
      "match": {
        "links.ip_address": {          <--------------------- change here
          "query": "10.214.159.193",
          "operator": "OR",
          "prefix_length": 0,
          "max_expansions": 50,
          "fuzzy_transpositions": true,
          "lenient": false,
          "zero_terms_query": "NONE",
          "auto_generate_synonyms_phrase_query": true,
          "boost": 1
        }
      }
    },
    "path": "links",
    "ignore_unmapped": false,
    "score_mode": "none",
    "boost": 1
  }
}

В коде:

String fullName = docName + "." + name;
QueryBuilder innerQuery = QueryBuilders.matchQuery(fullName, value);
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...