Elasticsearch 聚合查询(Aggregation)详解

news/2025/1/16 1:45:03/

Elasticsearch中的聚合查询,类似SQL的SUM/AVG/COUNT/GROUP BY分组查询,主要用于统计分析场景。

实例:

import org.apache.http.HttpHost;
import org.elasticsearch.action.search.SearchRequest;
import org.elasticsearch.action.search.SearchResponse;
import org.elasticsearch.client.RequestOptions;
import org.elasticsearch.client.RestClient;
import org.elasticsearch.client.RestClientBuilder;
import org.elasticsearch.client.RestHighLevelClient;
import org.elasticsearch.index.query.*;
import org.elasticsearch.search.aggregations.AggregationBuilders;
import org.elasticsearch.search.aggregations.Aggregations;
import org.elasticsearch.search.aggregations.bucket.terms.Terms;
import org.elasticsearch.search.aggregations.bucket.terms.TermsAggregationBuilder;
import org.elasticsearch.search.aggregations.metrics.Avg;
import org.elasticsearch.search.builder.SearchSourceBuilder;import java.io.IOException;public class Main {public static void main(String[] args) throws IOException {// 首先创建RestClient,后续章节通过RestClient对象进行参数配置。RestClientBuilder restClientBuilder = RestClient.builder(new HttpHost("localhost", 9200, "http"), // 设置ES服务地址,支持多个new HttpHost("localhost", 9201, "http"));// 创建RestHighLevelClient,请求都是通过RestHighLevelClient实例发出去的。RestHighLevelClient client = new RestHighLevelClient(restClientBuilder);// 创建SearchRequest对象, 设置查询索引名=orderSearchRequest searchRequest = new SearchRequest("order");// 通过SearchSourceBuilder构建搜索参数SearchSourceBuilder builder = new SearchSourceBuilder();// 通过QueryBuilders构建ES查询条件,这里查询所有文档,复杂的查询语句设置请参考前面的章节。builder.query(QueryBuilders.matchAllQuery());// 创建terms桶聚合,聚合名字=by_shop, 字段=shop_id,根据shop_id分组TermsAggregationBuilder aggregationBuilder = AggregationBuilders.terms("by_shop").field("shop_id");// 嵌套聚合// 设置Avg指标聚合,聚合名字=avg_price, 字段=price,计算平均价格aggregationBuilder.subAggregation(AggregationBuilders.avg("avg_price").field("price"));// 设置聚合查询builder.aggregation(aggregationBuilder);// 设置搜索条件searchRequest.source(builder);// 如果只想返回聚合统计结果,不想返回查询结果可以将分页大小设置为0builder.size(0);// 执行ES请求SearchResponse searchResponse = client.search(searchRequest, RequestOptions.DEFAULT);// 处理聚合查询结果Aggregations aggregations = searchResponse.getAggregations();// 根据by_shop名字查询terms聚合结果Terms byShopAggregation = aggregations.get("by_shop");// 遍历terms聚合结果for (Terms.Bucket bucket  : byShopAggregation.getBuckets()) {// 因为是根据shop_id分组,因此可以直接将桶的key转换成int类型int shopId = bucket.getKeyAsNumber().intValue();// 根据avg_price聚合名字,获取嵌套聚合结果Avg avg = bucket.getAggregations().get("avg_price");// 获取平均价格double avgPrice = avg.getValue();}// 关闭ES Clientclient.close();}
}

例子聚合统计的效果等价SQL:

select shop_id, avg(price) as avg_price from order group by shop_id


http://www.ppmy.cn/news/1246987.html

相关文章

产品经理提问常用的ChatGPT通用提示词模板

如何评估产品市场的潜力和可行性? 如何定义和明确产品的目标用户和需求? 如何进行竞品分析和比较,制定产品的差异化策略? 如何设计产品的功能和特性,满足用户需求? 如何制定产品的定价策略和销售计划&a…

耗时一个星期整理的APP自动化测试工具大全

在本篇文章中,将给大家推荐14款日常工作中经常用到的测试开发工具神器,涵盖了自动化测试、APP性能测试、稳定性测试、抓包工具等。 一、UI自动化测试工具 1. uiautomator2 openatx开源的ui自动化工具,支持Android和iOS。主要面向的编程语言…

距离向量路由协议——IGRP和EIGRP

IGRP-内部网关路由协议 IGRP(Interior Gateway Routing Protocol,内部网关路由协议)是一种动态距离向量路由协议,它是Cisco公司在20世纪80年代中期设计的,是Cisco专用路由协议。目前在Cisco高版本的IOS已经对IGRP不提…

血的教训--redis被入侵之漏洞利用复现--总览

血的教训–redis被入侵之漏洞利用复现–总览 相信大家对于自己的服务器被入侵,还是比较憎恨的,我的就被攻击了一次,总结经验,自己也是整理了这一个系列,从最基础到最后面的自己总结被攻破的步骤,非常清晰的…

CeresPCL 曲线拟合之三次多项式

文章目录 一、简介2.1 实现步骤二、实现代码三、实现效果参考资料一、简介 2.1 实现步骤 (1)构建代价函数。假设我们得到了一组数据,也知晓该数据是用曲线方程: y = a x 3 + b x 2 + c x +

idea 2023使用技巧(一)

IntelliJ IDEA在业界被公认为最好的java开发工具之一。它能给你良好的开发体验。 idea版本号为2023.2.5。 1 基础操作 1.1索引 idea首次加载项目时,都会创建索引,创建索引的时间跟项目的文件多少成正比。idea的缓存和索引主要是用来加快文件查询&…

Metasploit框架(2), MSF信息搜集

Metasploit框架(2), MSF信息搜集 路径以auxiliary开头的都是辅助模块, 比如auxiliary/scanner/smb/smb_version. 信息搜集一般使用nmap和辅助模块下的各种扫描器. 1. db_nmap db_nmap参数的用法与nmap命令相同. db_nmap -sn 192.168.112.1/24 # 扫描存活主机 db_nmap --scr…

Mysql并发时常见的死锁及解决方法

使用数据库时,有时会出现死锁。对于实际应用来说,就是出现系统卡顿。 死锁是指两个或两个以上的事务在执行过程中,因争夺资源而造成的一种互相等待的现象。就是所谓的锁资源请求产生了回路现象,即死循环,此时称系统处于…