Java使用ES条件构造器BoolQueryBuilder
1. 检索前构造
SearchRequest searchRequest = new SearchRequest("data_info");
SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();
sourceBuilder.trackTotalHits(true);
BoolQueryBuilder bqb = QueryBuilders.boolQuery();
2. 条件构造
- must可用filter代替,查询效率会更高,因为must会对结果进行_score评估
bqb.must(QueryBuilders.matchQuery("code", 666L);
bqb.must(QueryBuilders.matchPhraseQuery("name", "张");
bqb.must(QueryBuilders.termsQuery("code", new Long[]{1L, 2L, 3L});
bqb.must(QueryBuilders.termsQuery("code", 1L, 2L, 3L);
BoolQueryBuilder shouldQuery = QueryBuilders.boolQuery();
shouldQuery.should(QueryBuilders.matchQuery("code", 1L);
shouldQuery.should(QueryBuilders.matchQuery("code", 2L);
shouldQuery.minimumShouldMatch(1);
bqb.must(shouldQuery);
bqb.must(QueryBuilders.existsQuery("iden"));
bqb.mustNot(QueryBuilders.existsQuery("iden"));
bqb.must(QueryBuilders.rangeQuery("time").gte(new Date());
bqb.must(queryBuilder.matchPhraseQuery("key", value));
bqb.must(queryBuilder.multiMatchQuery(value, key1, key2, key3));
3. 构造完成进行查询
sourceBuilder.query(bqb);
sourceBuilder.sort("updateTime", SortOrder.DESC);
sourceBuilder.from((dto.getPageNum() - 1) * dto.getPageSize());
sourceBuilder.size(dto.getPageSize());
searchRequest.source(sourceBuilder);
SearchResponse searchResponse = client.search(searchRequest, RequestOptions.DEFAULT);
SearchHit[] hits = searchResponse.getHits().getHits();
for (int i = 0; i < hits.length; i++) {
System.out.println("返回的结果: " + hits[i].getSourceAsString());
}
log.info("返回总数为:" + searchResponse.getHits().getTotalHits());
int total = (int)searchResponse.getHits().getTotalHits().value;