Elasticsearch 7.X-8.0 AggregationBuliders 相关聚合函数(三)直方图/条形图 聚合

三、直方图(条形图)

  • histogram

    • 可应用于从文档中提取的数值或数值范围值。它会在值上动态构建固定大小(也称为间隔)的存储桶
    • 常常应用于图表类的展示数据
    • 请求示例:
    • POST /sales/_search?size=0
      {
        "aggs": {
          "prices": {
            "histogram": {
              "field": "price",
              "interval": 50
            }
          }
        }
      }

      返回示例:

    • {
        ...
        "aggregations": {
          "prices": {
            "buckets": [
              {
                "key": 0.0,
                "doc_count": 1
              },
              {
                "key": 50.0,
                "doc_count": 1
              },
              {
                "key": 100.0,
                "doc_count": 0
              },
              {
                "key": 150.0,
                "doc_count": 2
              },
              {
                "key": 200.0,
                "doc_count": 3
              }
            ]
          }
        }
      }

  • dateHistogram

    • 与上一个聚合类似,但只能与日期或日期范围值一起使用。由于日期在 Elasticsearch 内部表示为长值,因此在日期上也可以使用正常值,但并不那么准确。这两个 API 的主要区别在于,此处可以使用日期/时间表达式指定间隔。基于时间的数据需要特殊支持,因为基于时间的间隔并不总是固定的长度。‎
    • 间隔的类型可以自己设置,提供如下类型
      • 分钟, ‎‎1m‎
        • ‎所有分钟从 00 秒开始。一分钟是指定时区中第一分钟 00 秒和下一分钟 00 秒之间的间隔,补偿任何中间的闰秒,因此小时过后的分钟数和秒数在开始和结束时相同。‎
      • ‎小时, ‎‎1h‎
        • ‎所有小时从 00 分 00 秒开始。一小时 (1h) 是指定时区中第一个小时的 00:00 分钟和下一个小时的 00:00 分钟之间的间隔,补偿任何中间的闰秒,因此小时后的分钟数和秒数在开始和结束时相同。‎
      • ‎天, ‎‎1d
        • ‎所有日子都从最早的时间开始,通常是 00:00:00(午夜)。一天 (1d) 是指定时区中一天的开始和第二天的开始之间的间隔,用于补偿任何中间的时间更改。‎
      • ‎周, ‎‎1w‎
        • ‎一周是开始day_of_week:小时:分钟:秒与指定时区中一周的同一天和下一周的时间之间的间隔。‎
      • 月, ‎‎1M‎
        • ‎一个月是指定时区中该月的开始日和一天中的时间与该月的同一天和下个月的同一时间之间的间隔,因此该月的某一天和一天中的时间在开始和结束时是相同的。‎
      • , ‎‎1q‎
        • ‎一个季度是月份开始日和一天中的时间与三个月后的同一天和一天中的时间之间的间隔,因此月份中的某一天和一天中的时间在开始和结束时是相同的。‎
      • ‎‎‎年, ‎‎1y‎
        • ‎一年是指定时区中月份和一天中的开始日期与下一年的同一天和一天中的同一天之间的间隔,因此日期和时间在开始和结束时相同。‎
    • 请求示例:
    • POST /sales/_search?size=0
      {
        "aggs": {
          "sales_over_time": {
            "date_histogram": {
              "field": "date",
              "calendar_interval": "1M",
              "format": "yyyy-MM-dd" 
            }
          }
        }
      }

      返回示例:

    • {
        ...
        "aggregations": {
          "sales_over_time": {
            "buckets": [
              {
                "key_as_string": "2015-01-01",
                "key": 1420070400000,
                "doc_count": 3
              },
              {
                "key_as_string": "2015-02-01",
                "key": 1422748800000,
                "doc_count": 2
              },
              {
                "key_as_string": "2015-03-01",
                "key": 1425168000000,
                "doc_count": 2
              }
            ]
          }
        }
      }

      我们也可以设置固定间隔,或除以上类型的其他时间间隔,比如秒、毫秒、几周、几月等,可以参考官方文档:开发文档

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ERROR Failed to compile with 48 errors 上午10:53:54 These dependencies were not found: * core-js/modules/es.array.push.js in ./node_modules/.store/@babel+runtime@7.22.6/node_modules/@babel/runtime/helpers/esm/objectSpread2.js, ./node_modules/.store/cache-loader@4.1.0/node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/.store/babel-loader@8.3.0/node_modules/babel-loader/lib!./node_modules/.store/cache-loader@4.1.0/node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/.store/vue-loader@15.10.1/node_modules/vue-loader/lib??vue-loader-options!./src/components/HeaderSearch/index.vue?vue&type=script&lang=js& and 29 others * core-js/modules/es.error.cause.js in ./node_modules/.store/@babel+runtime@7.22.6/node_modules/@babel/runtime/helpers/esm/regeneratorRuntime.js, ./node_modules/.store/cache-loader@4.1.0/node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/.store/babel-loader@8.3.0/node_modules/babel-loader/lib!./node_modules/.store/cache-loader@4.1.0/node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/.store/vue-loader@15.10.1/node_modules/vue-loader/lib??vue-loader-options!./src/layout/components/Navbar.vue?vue&type=script&lang=js& and 5 others * core-js/modules/es.object.proto.js in ./node_modules/.store/@babel+runtime@7.22.6/node_modules/@babel/runtime/helpers/esm/regeneratorRuntime.js * core-js/modules/es.regexp.dot-all.js in ./node_modules/.store/cache-loader@4.1.0/node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/.store/babel-loader@8.3.0/node_modules/babel-loader/lib!./node_modules/.store/cache-loader@4.1.0/node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/.store/vue-loader@15.10.1/node_modules/vue-loader/lib??vue-loader-options!./src/components/ThemePicker/index.vue?vue&type=script&lang=js&, ./node_modules/.store/cache-loader@4.1.0/node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/.store/babel-loader@8.3.0/node_modules/babel-loader/lib!./node_modules/.store/cache-loader@4.1.0/node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/.store/vue-loader@15.10.1/node_modules/vue-loader/lib??vue-loader-options!./src/layout/components/Navbar.vue?vue&type=script&lang=js& and 2 others * core-js/modules/web.url-search-params.delete.js in ./src/utils/request.js * core-js/modules/web.url-search-params.has.js in ./src/utils/request.js * core-js/modules/web.url-search-params.size.js in ./src/utils/request.js * qs in ./src/utils/request.js * svg-baker-runtime/browser-symbol in ./src/icons/svg/user.svg To install them, you can run: npm install --save core-js/modules/es.array.push.js core-js/modules/es.error.cause.js core-js/modules/es.object.proto.js core-js/modules/es.regexp.dot-all.js core-js/modules/web.url-search-params.delete.js core-js/modules/web.url-search-params.has.js core-js/modules/web.url-search-params.size.js qs svg-baker-runtime/browser-symbol怎么解决如何安装
最新发布
07-21

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值