我是 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:
查找指定字段包含与指定模式匹配的术语的文档,其中模式支持单字符通配符 (?( 和多字符通配符 (*(
有关在单个查询中应用多个过滤器,请参阅此答案。