news 2026/4/18 13:28:34

Elasticsearch 聚合入门:像 Excel 透视表一样分析数据

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Elasticsearch 聚合入门:像 Excel 透视表一样分析数据

👋 你好,数据分析新手!

你是否熟悉 Excel 的透视表?它能轻松地对数据进行分组、求和、求平均,让你从一堆乱麻中快速看出端倪。

今天,我要告诉你一个好消息:Elasticsearch (ES) 也有一个“超级透视表”功能,它叫做“聚合 (Aggregation)”

如果说查询 (query) 是从 ES 的“图书馆”里找书,那么聚合 (aggregation) 就是对这些书进行统计分析,比如“哪个作者的书最多?”、“平均每本书有多少页?”。

这篇文章将带你用最直观的方式,入门 ES 的聚合功能。


🛠️ 聚合的“菜谱”:基本结构

和查询类似,聚合请求也有一个标准的 JSON 结构。我们同样通过_search端点发送,但这次我们把聚合指令放在aggs(aggregations 的缩写) 字段里。

# 基本结构GET /你的索引名称/_search{"size":0, // 设置为0,表示不返回具体文档,只返回聚合结果,更高效"aggs":{//"aggs""aggregations"的缩写"你给结果起的名字":{// 比如"avg_price""聚合类型":{// 比如"avg""字段":"字段名"// 比如"price"}}}}

别担心,下面的例子会让这个“菜谱”变得生动起来。


🧩 核心聚合类型:你的“数据积木”

聚合主要分为两大类,理解了它们,你就理解了聚合的精髓。

1. 桶聚合 (Bucket Aggregation) - “分组”

这是什么?
桶聚合就像 Excel 透视表里的“行”或“列”,它负责将数据分门别类地放进不同的“桶”里。例如,按“商品类别”分组,每个类别就是一个“桶”。

最常用的桶聚合:terms
terms聚合会为你统计每个“桶”里有多少文档。

场景: 统计一个“商品”索引中,每个**类别(category)**下有多少商品。

GET/products/_search{"size":0,"aggs":{"products_by_category":{// 我们给这个聚合结果起个名字"terms":{"field":"category.keyword"// 按 category 字段分组}}}}
  • category.keyword: 通常对文本字段进行分组时,我们使用.keyword后缀,以确保 ES 对整个词进行精确分组,而不是分词。

返回结果可能像这样

{..."aggregations":{"products_by_category":{"buckets":[{"key":"电子产品","doc_count":150},{"key":"家居用品","doc_count":80},{"key":"图书","doc_count":200}]}}}

看,是不是很清晰?ES 告诉你,“电子产品”这个桶里有150个商品,“家居用品”有80个。这就像透视表的行标签和计数!

2. 指标聚合 (Metrics Aggregation) - “计算”

这是什么?
指标聚合就像 Excel 透视表里的“值”区域,它负责对放进“桶”里的数据进行数学计算。例如,求平均值、总和、最大值、最小值等。

常用的指标聚合

  • avg:计算平均值
  • sum:计算总和
  • max/min:计算最大/最小值
  • cardinality:计算不重复值的数量(类似COUNT(DISTINCT column)

场景: 计算所有商品的平均价格(price)

GET/products/_search{"size":0,"aggs":{"average_price":{// 结果名"avg":{// 聚合类型:平均值"field":"price"// 要计算的字段}}}}

返回结果可能像这样

{..."aggregations":{"average_price":{"value":256.8// 直接返回计算出的值}}}

🚀 组合起来!像透视表一样工作

现在,让我们把“桶”和“指标”组合起来,完成一个真正的“透视表”操作。

终极场景统计每个商品类别下的平均价格是多少?

这就像在 Excel 透视表里:

  • :商品类别 (Category) ->terms桶聚合
  • :价格的平均值 (Average of Price) ->avg指标聚合

ES 查询语句

GET/products/_search{"size":0,"aggs":{"avg_price_by_category":{// 第一层聚合:按类别分组(桶)"terms":{"field":"category.keyword"},"aggs":{// 在每个类别的“桶”内部,再进行子聚合"avg_price":{// 给子聚合起个名字"avg":{// 子聚合类型:计算平均值"field":"price"}}}}}}

返回结果可能像这样

{..."aggregations":{"avg_price_by_category":{"buckets":[{"key":"电子产品",// 桶1:电子产品"doc_count":150,"avg_price":{"value":1200.50}// 桶1的平均值},{"key":"家居用品",// 桶2:家居用品"doc_count":80,"avg_price":{"value":150.00}// 桶2的平均值},{"key":"图书",// 桶3:图书"doc_count":200,"avg_price":{"value":45.80}// 桶3的平均值}]}}}

这不就是你想要的透视表结果吗?!清晰、直观,一目了然。


💡 总结与下一步

恭喜你!你已经掌握了 ES 聚合的核心思想:

  1. 桶聚合 (terms):像透视表的行/列,用来分组
  2. 指标聚合 (avg,sum等):像透视表的,用来计算
  3. 组合使用:在桶聚合内部嵌套指标聚合,实现强大的分层分析。

你的入门实践路径

  1. 打开 Kibana 的Dev Tools
  2. 找一个你熟悉的索引(比如网站日志、商品数据等)。
  3. 尝试用terms聚合对某个字段(如国家、城市、分类)进行分组。
  4. 再尝试在分组的基础上,计算某个数值字段(如价格、访问量)的平均值或总和。

ES 的聚合功能远不止于此,还有日期直方图 (date_histogram)、过滤 (filter)、嵌套聚合等更高级的玩法。但掌握了今天的“桶+指标”组合,你已经能解决 80% 的数据分析需求了!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/17 22:33:45

5、字符串、正则表达式与流操作的实用技巧

字符串、正则表达式与流操作的实用技巧 1. 字符串与正则表达式 在处理字符串时,正则表达式是非常强大的工具。下面介绍几个常见的字符串处理场景及对应的正则表达式应用。 1.1 最长回文子串 回文串是指正读和反读都相同的字符串。可以通过动态规划的方法来找出字符串中的最…

作者头像 李华
网站建设 2026/4/18 10:48:05

16、密码学与网络服务编程实战

密码学与网络服务编程实战 1. 密码学相关操作 1.1 计算文件哈希值 文件哈希常用于确保内容完整性,如从网络下载文件时。这里使用 Crypto++ 库来计算文件哈希值。以下是相关组件介绍: - FileSource :使用 BufferedTransformation 从文件读取数据,默认以 4096 字节块…

作者头像 李华
网站建设 2026/4/18 9:52:29

17、网络服务与数据交互:比特币汇率、邮件获取与文本翻译

网络服务与数据交互:比特币汇率、邮件获取与文本翻译 在当今数字化时代,网络服务在各个领域都发挥着重要作用。本文将详细介绍如何利用网络服务实现比特币汇率查询、邮件获取以及文本翻译等功能。 1. 比特币汇率查询 1.1 在线服务与API 许多在线服务提供了用于查询比特币…

作者头像 李华
网站建设 2026/4/18 7:45:23

18、使用微软认知服务进行图片人脸检测

使用微软认知服务进行图片人脸检测 在图像处理领域,人脸检测是一个常见且重要的问题。微软认知服务中的 Face API 为我们提供了强大的解决方案,它不仅可以检测人脸,还能识别性别、年龄、情绪等多种面部特征。 1. Face API 概述 Face API 是微软认知服务的一部分,提供了一…

作者头像 李华
网站建设 2026/4/18 3:52:21

基于 PLC 的立体车库设计之旅:西门子 S7 - 1200 的奇妙应用

基于PLC的立体车库的设计,西门子S7-1200PLC程序及组态仿真,电路图,IO表,博途15.1在自动化停车领域,基于 PLC(可编程逻辑控制器)的立体车库设计正逐渐成为主流解决方案。今天咱们就来深入探讨基于…

作者头像 李华
网站建设 2026/4/18 8:55:17

【SpringMVC】实现文件上传

SpringMVC的入门案例&#xff0c;创建 MavenJavaWeb 工程&#xff0c;在 pom 文件中引入开发的jar包&#xff0c;具体的坐标如下 <properties><spring.version>5.0.2.RELEASE</spring.version></properties><dependencies><dependency>&l…

作者头像 李华