RestClient-多条件聚合

在对应的service层里面写:

 

 HotelService里的代码如下:

@Override
    public Map<String, List<String>> filters()  {

        try {
            //1. 准备Request
            SearchRequest request = new SearchRequest("hotel");
            //2. 准备DSL
            //2.1 设置size
            request.source().size(0);
            //2.2 聚合
            buildAggretgaion(request);

            //3. 发出请求
            SearchResponse response = client.search(request,RequestOptions.DEFAULT);

            //4. 解析结果
            Map<String,List<String>> result = new HashMap<String, List<String>>();
            Aggregations aggregations = response.getAggregations();
            //4.1 根据品牌(聚合名称)名称获取品牌的结果
            List<String> brandList = getAddByName(aggregations,"brandAgg");
            result.put("品牌",brandList); //放入map
            //4.2 根据城市(聚合名称)名称获取品牌的结果
            List<String> cityList = getAddByName(aggregations,"cityList");
            result.put("城市",cityList); //放入map
            //4.3 根据星级(聚合名称)名称获取品牌的结果
            List<String> starList = getAddByName(aggregations,"starList");
            result.put("星级",starList); //放入map

            return result;

        } catch (IOException e) {
            throw new RuntimeException();
        }
    }

    //(抽取出来的) 根据名称获取品牌的结果
    private List<String> getAddByName(Aggregations aggregations, String aggName) {
        //4.1 根据聚合名称获取聚合结果
        Terms brandTerms = aggregations.get(aggName);
        //4.2 获取buckets
        List<? extends Terms.Bucket> buckets = brandTerms.getBuckets();
        //4.3 遍历
        List<String> brandList = new ArrayList<String>();
        for(Terms.Bucket bucket : buckets){
            //4.4 获取key
            String key = bucket.getKeyAsString();
            brandList.add(key);

            System.out.println(key);
        }
        return brandList;
    }

    //抽取出来的 聚合
    private void buildAggretgaion(SearchRequest request) {
        request.source().aggregation(AggregationBuilders
                .terms("brandAgg")
                .field("brand")
                .size(10)
        );
        request.source().aggregation(AggregationBuilders
                .terms("cityAgg")
                .field("city")
                .size(10)
        );
        request.source().aggregation(AggregationBuilders
                .terms("starAgg")
                .field("starName.keyword")
                .size(10)
        );
    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,可以通过以下步骤实现: 1. 首先创建一个RestHighLevelClient客户端对象,连接到Elasticsearch集群。 2. 构建一个SearchRequest对象,并设置其索引和查询条件。 3. 构建一个TermsAggregationBuilder对象,并设置其字段名。 4. 将TermsAggregationBuilder对象添加到SearchRequest对象中的AggregationBuilder中。 5. 执行查询,获取查询结果,并从中提取聚合结果。 以下是示例代码: ```java // 创建RestHighLevelClient客户端对象 RestHighLevelClient client = new RestHighLevelClient( RestClient.builder(new HttpHost("localhost", 9200, "http"))); // 构建SearchRequest对象 SearchRequest searchRequest = new SearchRequest("index_name"); SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder(); searchSourceBuilder.query(QueryBuilders.matchAllQuery()); searchRequest.source(searchSourceBuilder); // 构建TermsAggregationBuilder对象 TermsAggregationBuilder aggregationBuilder = AggregationBuilders.terms("group_by_field").field("field_name"); // 将TermsAggregationBuilder对象添加到SearchRequest对象中 searchSourceBuilder.aggregation(aggregationBuilder); // 执行查询 SearchResponse searchResponse = client.search(searchRequest, RequestOptions.DEFAULT); // 获取聚合结果 Terms termsAggregation = searchResponse.getAggregations().get("group_by_field"); List<? extends Terms.Bucket> buckets = termsAggregation.getBuckets(); for (Terms.Bucket bucket : buckets) { System.out.println(bucket.getKeyAsString() + " " + bucket.getDocCount()); } // 关闭客户端连接 client.close(); ``` 其中,"index_name"为索引名,"field_name"为要进行分组聚合的字段名,"group_by_field"为聚合结果的名称。可以根据实际情况进行修改。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值