es的histogram直方图聚合和terms分组聚合

你提到的这两个 Elasticsearch aggs 聚合语句:


第一种:histogram 直方图聚合

json 复制代码
"aggs": {
  "DayDiagram": {
    "histogram": {
      "field": "${FiledName}",
      "interval": ${TimeInterval},
      "extended_bounds": {
        "min": ${StartTime},
        "max": ${EndTime}
      }
    }
  }
}

第二种:terms 分组聚合

json 复制代码
"aggs": {
  "Records": {
    "terms": {
      "field": "${GroupByField}",
      "size": ${PageSize}
    }
  }
}

它们的区别概览

特性/维度 histogram 聚合 terms 聚合
聚合类型 数值直方图(数值/时间区间) 分类聚合(类似 SQL GROUP BY
适用字段类型 long / integer / date 等数字类型 keyword.keyword 可聚合的字段类型
聚合规则 按固定步长分桶(如每5分钟、每100) 按字段值枚举分桶
桶的 key 是什么? 范围起点值(如 0、5、10、15) 具体字段值(如"蓝色","白色","黄色")
是否可控时间段? ✅ 可通过 extended_bounds 强制显示所有区间 ❌ 只能显示实际存在的数据
典型应用 时间趋势图、数值区间图 某字段的分布、频次分析
支持排序 ✅ 默认按桶 key 排序 ✅ 默认按 doc_count 排序,可自定义

示例解释对比

histogram 示例:每 5 分钟统计一次事件数(时间直方图)

json 复制代码
"aggs": {
  "DayDiagram": {
    "histogram": {
      "field": "EventTimeMillis",
      "interval": 300000,
      "extended_bounds": {
        "min": 1622505600000,
        "max": 1622592000000
      }
    }
  }
}

假设 EventTimeMillislong 类型,单位是毫秒,表示事件时间。

每 5 分钟(300000ms)统计一次数据,支持时间缺口补全。

非常适合画:流量趋势图、柱状图、折线图


terms 示例:按车牌颜色统计通过数量(字段聚合)

json 复制代码
"aggs": {
  "Records": {
    "terms": {
      "field": "PlateColor.keyword",
      "size": 10
    }
  }
}

返回文档中最常出现的 10 种车牌颜色。
terms 是最常用的聚合类型,等价于 SQL 的 GROUP BY

非常适合做:分类统计、占比分析、分组报表


图示理解(类比 SQL)

histogram:

sql 复制代码
SELECT floor(EventTimeMillis / 300000) * 300000 AS time_slot, COUNT(*) 
FROM table 
GROUP BY time_slot;

terms:

sql 复制代码
SELECT PlateColor, COUNT(*) 
FROM table 
GROUP BY PlateColor
LIMIT 10;

是否可以嵌套?

可以:

例如你可以在 histogram 桶内再嵌套 terms:

json 复制代码
"aggs": {
  "TimeSlot": {
    "histogram": {
      "field": "EventTimeMillis",
      "interval": 300000
    },
    "aggs": {
      "ByPlateColor": {
        "terms": {
          "field": "PlateColor.keyword"
        }
      }
    }
  }
}

效果:每5分钟 + 按车牌颜色统计,非常适合图表联动。


总结对比

项目 histogram terms
用途 时间/数值分桶 分类字段分桶
数据维度 连续区间(固定间隔) 离散值(不同字段值)
桶排序 默认按 key 升序 默认按 count 降序,可改按 key 排序
补全空值 ✅ 使用 extended_bounds 实现 ❌ 不支持
图表用途 趋势图、时间序列 饼图、条形图

相关推荐
ClouGence25 分钟前
不用搭复杂系统,也能做跨地域数据迁移?
大数据·数据库·saas
xixixi7777729 分钟前
Token 经济引爆 AI 产业加速:从百模大战到百虾大战,谁在定义 2026 的中国 AI?
大数据·人工智能·机器学习·ai·大模型·算力·通信
Gent_倪44 分钟前
数据建模概念解析
大数据·数据建模
永霖光电_UVLED1 小时前
Polar Light 获得了欧盟Eurostars计划的110万欧元(€1.1m)资助
大数据·人工智能·物联网·汽车·娱乐
琪伦的工具库1 小时前
批量excel文件删除列工具使用说明:按列号或列名批量删除/保留,支持预览与大文件优化
大数据·excel
武子康2 小时前
大数据-266 实时数仓-Canal + Kafka 实现 MySQL 数据库变更实时捕获
大数据·后端·kafka
TDengine (老段)2 小时前
中原油田引入时序数据库 TDengine:写入性能提升、存储成本下降 85%
大数据·数据库·人工智能·时序数据库·tdengine·涛思数据
财经资讯数据_灵砚智能2 小时前
基于全球经济类多源新闻的NLP情感分析与数据可视化(日间)2026年4月12日
大数据·人工智能·信息可视化·自然语言处理·ai编程
Crazy CodeCrafter2 小时前
现在做服装,实体和电商怎么选?
大数据·数据库·人工智能·微信·开源软件·零售
2601_954434552 小时前
2026年专业深度测评:入门电钢琴品牌排名前五权威发布
大数据·人工智能·python