我需要使用 ES REST 高级客户端 (Java) 创建类似于高级搜索的东西。
首先,我有一个搜索关键字可以搜索所有字段。
为此,我使用 QueryStringQueryBuilder
。
SearchSourceBuilder ticketInfoSourceBuilder = new SearchSourceBuilder();
ticketInfoSourceBuilder.from(pageable.getOffset());
ticketInfoSourceBuilder.size(pageable.getPageSize());
ticketInfoSourceBuilder.sort(new FieldSortBuilder(sortField).order(sortOrder));
ticketInfoSourceBuilder.query(QueryBuilders.queryStringQuery("ABC1234"));
现在,我需要使用 TermsQueryBuilder
添加更多过滤器。
是否可以合并这两个查询构建器?
我想添加以下过滤器:
"terms" : { "ticket.inquiryType" : ["INQTYP01", "INQTYP06"]}
"terms" : { "ticket.status" : ["NEW", "CLOSED"]}
"terms" : { "ticket.ownership" : ["OWNED", "OTHER_OWNER"]}
是否可以结合两个查询构建器来实现类似高级搜索的功能?
谢谢!
最佳答案
是的,您可以使用这样的 bool
查询来做到这一点:
QueryBuilder query = QueryBuilders.boolQuery()
.must(QueryBuilders.queryStringQuery("ABC1234"))
.filter(QueryBuilders.termsQuery("ticket.inquiryType", "INQTYP01", "INQTYP06"))
.filter(QueryBuilders.termsQuery("ticket.status", "NEW", "CLOSED"))
.filter(QueryBuilders.termsQuery("ticket.ownership", "OWNED", "OTHER_OWNER"));
ticketInfoSourceBuilder.query(query);
关于java - Elasticsearch REST 高级客户端结合了查询构建器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50691758/