Я работаю на Java с Elastic-search и хочу фильтровать данные по параметру «содержит строку».
Например: получить список детей, имена которых начинаются с буквы «r».
Но поисковый запрос (код ниже) возвращает список дочерних элементов с именами, равными (не содержащими) «r».
Я пробовал «г *» - не повезло.
builder.must(QueryBuilders.queryStringQuery("r*")
.field("child_name")
.lenient(true)
.escape(true)
.analyzeWildcard(false)
.fuzziness(Fuzziness.ZERO)
.defaultOperator(Operator.AND)
.boost(2.0f));
}




Попробуйте другой тип QueryBuilder - WildcardQueryBuilder:
Implements the wildcard search query. Supported wildcards are *, which matches any character sequence (including the empty one), and ?, which matches any single character. Note this query can be slow, as it needs to iterate over many terms. In order to prevent extremely slow WildcardQueries, a Wildcard term should not start with one of the wildcards * or ?.
Пример:
QueryBuilder qb = QueryBuilders.wildcardQuery("user", "k?mc*");
Наконец, я сам нашел проблему. У меня было две проблемы:
.analyzeWildcard(false)
.boost(2.0f))
Я меняю на:
.analyzeWildcard(true)
.boost(1.0f))
И это помогло.
Привет, Моя проблема заключалась в .analyzeWildcard (false) и повышении (2.0f)); Я изменил его, и теперь все в порядке, но спасибо и голосование.