Elastic Search 聚合查询

在es简单查询之外,还有更高级的聚合查询,这些基本上都是会大大减少生成需求数据所需的时间。

如果说 Query 决定查哪些文档,

Aggregation 决定从这些文档里能算出什么世界。

这其中就包括:

1.value_count:统计字段非空数量

得到该索引的数量之和,一般用于列表展示

js 复制代码
GET order_index/_search 
    { "size": 0, 
      "aggs": 
        { "order_count": 
            { "value_count": { "field": "orderId" }} 
        } 
    }

2.terms:分组聚合

等同于group by

根据所选字段,自动分组并且得出数量,一般用于列表标签展示的时候来显示各个标签有多少数据。

js 复制代码
GET order_index/_search 
{ 
    "size": 0, 
    "aggs": 
        { "by_status": 
            { "terms": { "field": "status.keyword" }} 
        } 
 }

3.分组 + 指标聚合

根据分组的个个数据,对内求和

js 复制代码
GET order_index/_search 
{ "size": 0, 
    "aggs": { 
    "by_status": { 
        "terms": { "field": "status.keyword" },
        "aggs": { 
            "total_amount": { "sum": { "field": "amount" } }
           } 
        }
    } 
}

4.过滤 + 聚合

通过query过滤数据,在使用agg来聚合数据。

js 复制代码
GET order_index/_search 
{ "size": 0, 
    "query": { 
        "term": { "status.keyword": "PAID" } 
    }, 
    "aggs": { 
        "avg_amount": { "avg": { "field": "amount" } } 
    } 
}

5.date_histogram 时间聚合

根据时间格式进行聚合

js 复制代码
GET order_index/_search 
{ "size": 0, 
    "aggs": { 
        "order_by_day": { 
            "date_histogram": { 
            "field": "createTime", "calendar_interval": "day", "format": "yyyy-MM-dd" } 
        } 
    } 
}

6.Bucket 筛选

script 进行筛选,只能在聚合之后

js 复制代码
{"size": 0, 
    "aggs": { 
        "by_status": {
            "terms": { "field": "status.keyword" }, 
            "aggs": { 
                 "order_filter": { 
                     "bucket_selector": { 
                         "buckets_path": { "cnt": "_count" }, 
                         "script": "params.cnt >= 100"
                      }
                 }
             } 
        } 
     } 
}
相关推荐
为思念酝酿的痛12 小时前
POSIX信号量
linux·运维·服务器·后端
小羊在睡觉12 小时前
力扣84. 柱状图中最大的矩形
后端·算法·leetcode·golang·go
swipe13 小时前
Neo4j + Graph RAG 医疗知识图谱工程实践:患者教育问答真正需要的是“关系可追溯”
后端·langchain·llm
源码宝14 小时前
MES系统源码:Java8 + SpringBoot2.7 + MySQL8 + Redis,后端源码清爽易扩展
java·后端·源码·springboot·mes系统·源码二开·mes源码
金銀銅鐵15 小时前
[Java] 如何理解 class 文件中方法的 descriptor?
java·后端
村口张大爷15 小时前
05 — 分层架构与依赖倒置
后端·架构·系统架构
Jasonakeke16 小时前
SpringBoot自动配置原理揭秘
java·spring boot·后端
IT_陈寒17 小时前
Vite热更新失灵?你可能漏了这个配置
前端·人工智能·后端
uzong17 小时前
面试官:如何做好架构设计
后端·架构
Cosolar18 小时前
QwenPaw Agent 实现原理深度剖析
后端·面试·架构