集团主站
欢迎来到成都达内官方网站!达内—美国上市公司 亿元级外企IT培训企业!
成都it培训哪家好
成都it培训哪家好
全国服务监督电话:400-111-8989  |   联系客服   |
当前位置:主页 > 培训课程 > 大数据 >

[成都大数据培训哪家好]ElasticsearchTemplate嵌套聚合

发布者: 成都达内     浏览次数:     发布时间:2020-09-16 11:16:18

[成都大数据培训哪家好]ElasticsearchTemplate嵌套聚合,这一次主要写一个嵌套的聚合,例如先对sex集合,再对desc聚合,最后再对age求和,共三层嵌套。...

  这一次主要写一个嵌套的聚合,例如先对sex集合,再对desc聚合,最后再对age求和,共三层嵌套。

  Aggregations的部分特性类似于SQL语言中的group by,avg,sum等函数,Aggregations需要理解两个概念:

  桶(Buckets):符合条件的文档的集合,相当于SQL中的group by。按“性别”聚合,一个人将被分到男桶或女桶

  指标(Metrics):基于Buckets的基础上进行统计分析,并进行计算,大多数metric是数学计算,仅输出一个值,min/max/avg/sum/cardinality,部分metric支持输出多个数值,stats(统计)/percentiles(百分比)/percentile_ranks

  嵌套聚合写法 // 创建一个查询条件对象

  BoolQueryBuilder queryBuilder = QueryBuilders.boolQuery();

  // 拼接查询条件

  queryBuilder.should(QueryBuilders.termQuery("creator", "1"));

  // 创建聚合查询条件

  TermsAggregationBuilder sexAgg = AggregationBuilders

  .terms("sex")

  .field("sex.keyword");//keyword表示不使用分词进行聚合,全字匹配

  TermsAggregationBuilder descAgg = AggregationBuilders

  .terms("desc")

  .field("desc.keyword");//keyword表示不使用分词进行聚合,全字匹配

  SumAggregationBuilder ageSumAgg = AggregationBuilders

  .sum("ageSum")

  .field("age");

  //嵌套

  descAgg.subAggregation(ageSumAgg);

  sexAgg.subAggregation(descAgg);

  // 创建查询对象

  SearchQuery build = new NativeSearchQueryBuilder()

  .withQuery(queryBuilder) //添加查询条件

  .addAggregation(sexAgg) // 添加聚合条件

  .withPageable(PageRequest.of(0, 1)) //符合查询条件的文档分页,如果文档比较大,可以把这个分页改小(不是聚合的分页)

  .build();

  // 执行查询

  AggregatedPage testEntities = elasticsearchTemplate.queryForPage(build, TestEsDto.class);

  // 取出聚合结果

  Aggregations entitiesAggregations = testEntities.getAggregations();

  Terms terms = (Terms) entitiesAggregations.asMap().get("sex");

  // 遍历取出聚合字段列的值,与对应的数量

  for (Terms.Bucket bucket : terms.getBuckets()) {

  Terms descTerms = (Terms) bucket.getAggregations().asMap().get("desc");

  for (Terms.Bucket descTermsBucket : descTerms.getBuckets()) {

  ParsedSum parsedSum = descTermsBucket.getAggregations().get("ageSum");//注意从bucket而不是searchResponse

  System.out.println(bucket.getKeyAsString() + "\t" +

  bucket.getDocCount() + "\t" +

  descTermsBucket.getKeyAsString() + "\t" +

  parsedSum.getValueAsString());

  }

  }

  结果

  [成都大数据培训哪家好]ElasticsearchTemplate嵌套聚合

(责任编辑:范老师)
最新开班
  • 成都Java培训班
    免费试听名额发放中...
  • 成都C++培训班
    免费试听名额发放中...
  • 成都PHP培训班
    免费试听名额发放中...
  • 成都网络工程培训班
    免费试听名额发放中...
  • 成都Unity3D培训班
    免费试听名额发放中...
  • 成都大数据培训班
    免费试听名额发放中...
  • 成都uid培训班
    免费试听名额发放中...
  • 成都会计培训班
    免费试听名额发放中...
  • 成都Python培训班
    免费试听名额发放中...
  • 成都嵌入式培训班
    免费试听名额发放中...
  • 成都web培训班
    免费试听名额发放中...
  • 成都软件测试培训班
    免费试听名额发放中...
在线留言
提交

校区地址:成都市锦江区东大街紫东楼端35号明宇金融广场19楼1906室

联系电话:400-111-8989

公交路线:芷泉街(18路;21路;43路;48路;104路;152路;335路 ) 地铁路线:东门大桥站(地铁2号线)

校区地址:成都市高新区奥克斯广场蜀锦路209号一楼商铺

联系电话:400-111-8989

公交路线:益州大道锦城大道口(18路;21路;43路;48路;104路;152路;335路 ) 地铁路线:孵化园(地铁1号线)

校区地址:成都锦江区东大街芷泉街229号东方广场C座3楼303

联系电话:400-111-8989

公交路线:芷泉街(188路;115路;515路;236路;505路;501路;84路 ) 地铁路线:东门大桥站(地铁2号线)

校区地址:成都市武侯区佳灵路3号红牌楼广场2号写字楼11楼1115号

联系电话:400-111-8989

公交路线:红牌楼东(11路;92路;100路;111路;139路;g28路;快速公交K1/K2) 地铁路线:红牌楼站(地铁3号线)

校区地址:成都市锦江区红星路二段70号四川日报大厦502-2

联系电话:400-111-8989

公交路线:市二医院站(6路;49路;102路;5路;37路;g92路;) 地铁路线:地铁市二医院(地铁3号线)

校区地址:成都市锦江区东大街芷泉段229号东方广场C座16层

联系电话:400-111-8989

公交路线:芷泉街(18路;21路;43路;48路;104路;152路;335路 ) 地铁路线:东门大桥站(地铁2号线)

校区地址:四川省成都市武侯区高新科技孵化园9号园区E座7楼

联系电话:400-111-8989

公交路线:益州大道锦城大道口(18路;21路;43路;48路;104路;152路;335路 ) 地铁路线:孵化园(地铁1号线)

了解达内动态
关注成都达内教育公众号

首页 | 关于达内 | 课程中心 | 专家师资 | 视频教程 | 学员空间 | 校企合作 | 新闻资讯 | 就业指导 | 网站地图

2016-2025 达内时代科技集团有限公司 版权所有 京ICP证8000853号-56 蜀ICP备18021046号-3