elasticsearch的group by分组和sum求和

最近在使用es查询某个字段在特定查询条件下的某个字段的求和时,忘记了query语句是怎么写的,简单记录一下,方便自己和他人查阅。

一 什么是elasticsearch?

elasticsearch是一个分布式的使用 REST 接口的搜索引擎,简称为ES,它是面向文档的,可以存储整个对象或文档。

二:elasticsearch的几种操作

1 对某个字段求和,相当于sql语句的:

select sum(字段名) from table where 条件1  and 条件2
#对某个字段求和操作

{
  "query": {
    "bool": {
      "must": [
        {
          "range": {
            "条件1": {
              "gte": "2022-05-08",
              "lte": "2022-05-14"
            }
          }
        },
        {
          "match": {
            "条件1": "***"
          }
        }
      ],
      "must_not": [],
      "should": []
    }
  },
  "from": 0,
  "size": 0,
  "sort": [],
  "aggs": {
    "求和后叫的字段名": {
      "sum": {
        "field": "求和字段"
      }
    }
  }
}

2 根据多个字段进行分组,相当于sql语句的:

select * from table where 条件1 and 条件2 group by XXX,YYY
#根据多个字段进行聚合

{
  "query": {
    "bool": {
      "must": [
        {
          "range": {
            "条件1": {
              "gte": "2022-05-08",
              "lte": "2022-05-08"
            }
          }
        },
        {
          "match": {
            "条件2": "J00371"
          }
        }
      ],
      "must_not": [],
      "should": []
    }
  },
  "from": 0,
  "size": 0,
  "sort": [],
  "aggregations": {
    "分组字段1": {
      "terms": {
        "field": "es索引中的字段1"
      },
      "aggregations": {
        "分组字段2": {
          "terms": {
            "field": "es索引中的字段2"
          }
        }
      }
    }
  }
}

3、向es中插入数据,相当于sql的:

insert into table (字段名1,字段名2,…………) VALUES (字段1的值,字段2的值,……);
PUT /索引名/type/8000
{
    "filed1": "value1",
    "filed2": "value2",
    "filed3": "value3",
    ………………
}

 

4、删除es的某复合条件的记录,相当于sql的:

delete from table where condition1 and condition2
{
    "query": {
        "bool": {
            "must": [
                {
                    "match": {
                        "condition1": "condition1"
                    }
                }
            ],
            "must_not": [],
            "should": []
        }
    }
}

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Elasticsearch 聚合和分组是为了对数据进行聚合和分类的操作。通过聚合,可以从多个文档或字段中获取统计信息,例如计算平均值、总和或占比等。分组则是将文档按照某个字段进行分类,例如将客户按照地域分组。这样可以方便地对数据进行分析和可视化。 ### 回答2: Elasticsearch是一个广为使用的开源搜索引擎,它具有强大的聚合能力,可以对数据进行分组、过滤、排序等操作。在Elasticsearch中,聚合是一个非常重要的功能,它可以从一组文档中抽取统计信息,并将其返回给用户。 聚合和分组的概念是密不可分的,聚合操作通常需要通过分组操作来实现。通过聚合和分组操作,我们可以将数据按照某个字段进行分类,比如说对商品按照价格进行分组,或者将用户按照地理位置进行分组等。为了更好地理解聚合和分组的概念,下面将分别解释这两个概念,在此基础上再介绍如何在Elasticsearch中进行聚合和分组操作。 什么是聚合? 聚合是指对一组数据进行统计和分析的过程,通过聚合操作,我们可以从数据中获得一些有价值的信息,比如说总数、平均值、最大值、最小值、分布情况、占比等等。 在Elasticsearch中,聚合是一种高级查询方式,可以在搜索结果中对数据进行进一步深入地挖掘,比如:常见的数据统计:例如通过terms统计某一列中每个值的数量,通过avg统计某一列的平均值,通过max统计某一列的最大值等。 什么是分组分组指的是按照某个字段对一组数据进行分组,将数据分成多个子集,在每个子集中进行聚合操作,最终将各个子集的结果合并得出整体结果。在Elasticsearch中,分组是通过聚合操作来实现的,可以通过terms聚合来对数据进行分组,也可以通过date_histogram聚合对时间数据进行分组。 如何在Elasticsearch中进行聚合和分组操作? Elasticsearch提供了丰富的聚合功能,可以通过简单的组合实现复杂的聚合操作。比如说,可以使用terms聚合来对数据进行分组,然后使用sum聚合来计算每个分组的总和。下面给出一个示例代码: ``` GET /my_index/_search { "size": 0, "aggs": { "group_by_price": { "terms": { "field": "price" }, "aggs": { "total_sales": { "sum": { "field": "sales" } } } } } } ``` 在上面的代码中,我们使用terms聚合来对数据进行分组,将数据按照price字段进行分组,然后使用sum聚合来计算每个分组的销售总数。这个例子只是聚合功能的冰山一角,在实际应用中,我们还可以使用Elasticsearch提供的其他聚合操作来实现更复杂的统计和分析需求。 通过上述方法和示例,我们可以看出,Elasticsearch的聚合和分组功能非常强大,可以快速地对大规模的数据进行统计和分析。对于需要进行数据分析和报告的企业和用户来说,Elasticsearch聚合和分组功能是绝对值得掌握和使用的。 ### 回答3: elasticsearch 是一款基于 Lucene 的开源搜索引擎。除了基本的文本搜索外,它还提供了强大的聚合和分组功能。 聚合是一种将多个文档组合在一起分析的方法,其结果可以是平均值、最大值、最小值等。可以使用 `aggs` 参数将查询结果进行聚合,常见的聚合类型有: - Bucket 聚合:将多个文档按照某种标准分组,使用 `terms` 或 `histogram` 等聚合函数实现。 - Metrics 聚合:计算符合条件的文档中某个字段的统计值,比如 `average`、`sum`、`max`、`min` 等聚合函数。 例如,以下查询使用 `terms` 聚合函数将所有文档按照 `age` 字段的值分为不同的组,并计算每组的文档数和平均年龄: ``` GET /_search { "size": 0, "aggs": { "age_buckets": { "terms": { "field": "age" }, "aggs": { "avg_age": { "avg": { "field": "age" } } } } } } ``` 分组是基于聚合的一种操作,是指将聚合后的结果按照某种标准进行分组。比如,可以使用 `nested` 和 `reverse_nested` 参数实现嵌套分组,使用 `min_doc_count` 设置分组最小文档数量。例如,以下查询将所有文档按照 `age` 和 `gender` 字段进行分组,并分别计算每组的文档数和平均年龄,然后再按照 `age` 进行反向分组: ``` GET /_search { "size": 0, "aggs": { "age": { "terms": { "field": "age" }, "aggs": { "gender": { "terms": { "field": "gender" }, "aggs": { "avg_age": { "avg": { "field": "age" } } } } } }, "reverse_age": { "reverse_nested": {}, "aggs": { "avg_age": { "avg": { "field": "age" } } } } } } ``` 总之,elasticsearch 的聚合和分组功能十分强大,可以根据实际需求进行灵活配置,以实现更精确的查询结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值