如何通过 Java 高级 rest 客户端在弹性搜索中使用多个字段进行搜索



我是 Elastic 搜索的新手。成功实现用于匹配单个字段的搜索文档 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%"

任何人都可以帮助如何在单个搜索请求中应用所有这些过滤器吗?

您可以使用文档中指定的范围查询:

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

对于模式,您可以使用通配符查询:

wildcardQuery(
"documentName",                                              
patternString); 

来自 Docs:
查找指定字段包含与指定模式匹配的术语的文档,其中模式支持单字符通配符 (?( 和多字符通配符 (*(

有关在单个查询中应用多个过滤器,请参阅此答案。

相关内容

  • 没有找到相关文章

最新更新