Elasticsearch聚合查询

三种类型的聚合

1、桶聚合

类似与SQL中的group by

text类型不能用于聚合查询、keyword

语法:常规聚合

复制代码
{
  "aggs":{ 
    "term_brand":{ //聚合名称
      "trems":{ //查询函数
        "field":"brand.keyword" //聚合字段
      }
    }
  }
}

范围聚合 查询价格为2000 、2000-5000、5000以上 范围内 各个手机的数量

复制代码
{
  "aggs":{
    "range_price":{ //聚合名称
        "range":{
          "field":"price",
          "ranges":[
            {
              "to":2000,
            },
            {
              "form":2000,
              "to":5000
            },
            {
              "from":5000
            }
          ]
        }
    }
  }
}

Multi Terms

当在聚合的时候需要对多个字段同时聚合的时候,可以使用multi_Terms来完成

复制代码
{
  "aggs":{ 
    "agg_name":{ //聚合名称
      "multi_terms":{//查询函数
        "trems":[
          { 
            "field":"field1" //聚合字段
          }	,
          { 
            "field":"field2" //聚合字段
          }	
        ]
      }
      
    }
  }
}
2、指标聚合

场景:用于统计某个指标,如最大值、最小值、平均值,可以使用桶聚合一起使用,如按照商品类型分桶,统计每个桶的平均价格

指标函数:

  • 平均值:Avg
  • 最大值:Max
  • 最小值:Min
  • 求和:Sum
  • 详细信息:Status
  • 数量:Value count

统计商品价格的 最大值、最小值、和平均值

复制代码
GET goods/_search
{
  "aggs":{
    "metric_max":{
      "max":{
        "field":"price"
      }
    },
    "metric_min":{
      "min":{
        "field":"price"
      }
    },
    "metric_avg":{
      "avg":{
        "field":"price "
      }
    }
  }
}

3、管道聚合

统计平均价格最低商品品牌

1、对品牌分桶

2、对每个桶计算平均价格

3、计算平均价格最低值

复制代码
GET goods/_search
{
  "aggs":{
    "agg_pip":{
      "terms":{
        "filed":"brand.keyword"
      },
      "aggs":{
        "avg_price":{
          "avg""{
            "field":"price"
          }
        }
      }
    }
  },
  "min_avg_price":{
    "min_bucket":{
      "buckets_path":"agg_pip>avg_price"
    }
  }
}
相关推荐
智慧景区与市集主理人3 小时前
五一乡村文旅增收难?巨有科技大数据双赋能破局突围
大数据·科技
TechubNews6 小时前
新火集团首席经济学家付鹏演讲——2026 年是 Crypto 加入到 FICC 资产配置框架元年
大数据·人工智能
Elastic 中国社区官方博客7 小时前
为 Elastic Cloud Serverless 和 Elasticsearch 引入统一的 API 密钥
大数据·运维·elasticsearch·搜索引擎·云原生·serverless
vastsmile9 小时前
(R)26.04.23 hermes agent执行本地命令超级慢的原因
开发语言·elasticsearch·r语言
CS创新实验室10 小时前
CS实验室行业报告:机器人领域就业分析报告
大数据·人工智能·机器人
老陈头聊SEO11 小时前
生成引擎优化(GEO)为内容创作引入新视角与用户体验提升策略
其他·搜索引擎·seo优化
LinuxGeek102413 小时前
Kylin-Server-V11、openEuler-22.03和openEuler-24.03的MySQL 9.7.0版本正式发布
大数据·mysql·kylin
容智信息13 小时前
国家级算力底座+企业级智能体:容智Agent OS 获选入驻移动云能中心,联手赋能千行百业
大数据·人工智能·自然语言处理·智慧城市
Chuer_13 小时前
讲透财务Agent核心概念,深度拆解财务Agent应用趋势
大数据·数据库·安全·数据分析·甘特图
gushinghsjj13 小时前
什么是主数据管理平台?怎么构建主数据管理平台?
大数据·数据库