ElasticSearch6.7--should和must多条件组合查询,并根据某值排序

       最开始做ES的时候,只是做单纯做查询,后续由于业务规则,涉及到组合复杂查询,去研究了一下ES,最主要的是BoolQueryBuilderl该类的使用--must和should方法。

        这里介绍一下主要几个类:

         RestHighLevelClient --rest高级客户端,主方法:search(),主参数:SearchRequest,RequestOptions

        SearchRequest --查询主类,主方法:source()主资源方法,主参数:SearchSourceBuilder

         

        SearchSourceBuilder --查询主类,主要方法:query()查询条件的拼装,参数:QueryBuilder;from(),size()分页方法;sort()排序方法,参数:SortBuilder<?>

完整代码如下:

SearchRequest searchRequest = new SearchRequest(index);
SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
BoolQueryBuilder mustBuilder = new BoolQueryBuilder();
BoolQueryBuilder shouldBuilder = new BoolQueryBuilder();
shouldBuilder.should(QueryBuilders.termQuery("a", esChatMessageReq.getUserId()));
shouldBuilder.should(QueryBuilders.termQuery("b", esChatMessageReq.getUserId()));
mustBuilder.must(QueryBuilders.matchQuery("c", esChatMessageReq.getMerCode())).must(shouldBuilder);
searchSourceBuilder.query(mustBuilder);
searchSourceBuilder.from((esChatMessageReq.getCurrentPage() - 1) * esChatMessageReq.getPageSize());
searchSourceBuilder.size(esChatMessageReq.getPageSize());
searchSourceBuilder.sort(new FieldSortBuilder("timeStamp").unmappedType("long").order(SortOrder.DESC));
searchRequest.source(searchSourceBuilder);
SearchResponse searchResponse = restHighLevelClient.search(searchRequest, RequestOptions.DEFAULT);

解析es数据:

SearchHits hits = searchResponse.getHits();
for (SearchHit searchHit : hits.getHits()) {
    String result = searchHit.getSourceAsString();
}

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值