(转)es多字段分组聚合3种实现方式

转自:

https://blog.csdn.net/OliverCaro/article/details/120763278


一、ElasticSearch的分组聚合
官网文档地址:
https://www.elastic.co/guide/en/elasticsearch/reference/current/search-aggregations-bucket-terms-aggregation.html#_multi_field_terms_aggregation

实现背景:实现类似SQL的group by功能:

select team,age from a_person group by team,age;

二、多字段分组聚合的三种实现方法(性能不高)
在ElasticSearch中,实现多字段分组聚合的方式包括:

1、使用 Script
使用脚本script从多个字段聚合分组:

dsl:
 

GET /_search
{
  "query": {
    "match_all": {}
  },
  "aggs": {
    "group_ab": {
      "terms": {
        "script": {
          "source": "doc['a'].value +','+ doc['b'].value",
          "lang": "painless"
        }
      }
    }
  }
}
}

2、使用 copy_to 字段(需要提前mapping,暂不考虑)
在创建索引的mapping时创建一个新的专用copy_to字段,后续可以在这个字段上进行汇总查询。

3、multi_terms 聚合
Multi Terms aggregation | Elasticsearch Guide [7.13] | Elastic

multi_terms 聚合将来自多个字段的术语组合成一个复合key。会禁用全局序数,并且比从单个term聚合要慢。

注意7.12版本新特性,旧版本不用考虑

dsl:
 

GET /products/_search
{
  "aggs": {
    "genres_and_products": {
      "multi_terms": {
        "terms": [{
          "field": "genre" 
        }, {
          "field": "product"
        }]
      }
    }
  }
}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值