Как искать по нескольким полям в Elasti c Искать через Java клиент для отдыха высокого уровня - PullRequest
1 голос
/ 18 июня 2020

Я новичок в поиске Elasti c. Успешно реализован API поискового документа для сопоставления одного поля, как показано ниже:

SearchRequest searchRequest = new SearchRequest(indexName);

//Single field match, only for documentId
QueryBuilder matchQueryBuilder = QueryBuilders.matchQuery("documentId", documentId); 

SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();
sourceBuilder.query(matchQueryBuilder);
searchRequest.source(sourceBuilder);

SearchResponse searchResponse = restHighLevelClient.search(searchRequest, RequestOptions.DEFAULT);

Я хочу отфильтровать данные с использованием нескольких полей в одном API, например, необходимо добавить больше фильтров в указанный выше API в соответствии с условием ниже:

documentNumber > 66 &&  (documentCreatedDate >= date1 && documentCreatedDate <= date2) && documentName like "%test%"

Может ли кто-нибудь помочь, как применить все эти фильтры в одном SearchRequest?

1 Ответ

1 голос
/ 18 июня 2020

Вы можете использовать rangeQuery , как указано в документах:

QueryBuilders.rangeQuery("documentNumber")                                             
    .gte(66); 
QueryBuilders.rangeQuery("documentCreatedDate")                                             
    .gte(date1)
    .lt(date2); 

Для шаблонов вы можете использовать wildcardQuery:

wildcardQuery(
        "documentName",                                              
        patternString); 

Из документов:
Найти документы, в которых указанное поле содержит термины, соответствующие указанному шаблону, где шаблон поддерживает односимвольные подстановочные знаки (?) И многосимвольные подстановочные знаки (*)

Для применения нескольких фильтров в одном запросе см. на это ответ.

...