es 时间字段聚合_ES之五:ElasticSearch聚合

1、单值聚合

Sum求和,dsl参考如下:

f2940af480e1b4b65ede0eee02de2ab9.png

{

"size": 0,

"aggs": {

"return_balance": {

"sum": {

"field": "balance"

}

}

}

}

f2940af480e1b4b65ede0eee02de2ab9.png

返回balance之和,其中size=0 表示不需要返回参与查询的文档。

20180110223510027532.png

Min求最小值

f2940af480e1b4b65ede0eee02de2ab9.png

{

"size": 0,

"aggs": {

"return_min_balance": {

"min": {

"field": "balance"

}

}

}

}

f2940af480e1b4b65ede0eee02de2ab9.png

返回结果

20180110223510031439.png

Max求最大值

f2940af480e1b4b65ede0eee02de2ab9.png

{

"size": 0,

"aggs": {

"return_max_balance": {

"max": {

"field": "balance"

}

}

}

}

f2940af480e1b4b65ede0eee02de2ab9.png

返回结果:

20180110223510033392.png

AVG求平均值

f2940af480e1b4b65ede0eee02de2ab9.png

{

"size": 0,

"aggs": {

"return_avg_balance": {

"avg": {

"field": "balance"

}

}

}

}

f2940af480e1b4b65ede0eee02de2ab9.png

返回结果:

20180110223510034368.png

Cardinality 求基数(如下示例,查找性别的基数 M、F,共两个)

f2940af480e1b4b65ede0eee02de2ab9.png

{

"size": 0,

"aggs": {

"return_cardinality": {

"cardinality": {

"field": "gender"

}

}

}

}

f2940af480e1b4b65ede0eee02de2ab9.png

结果为:

20180110223510036322.png

2、多值聚合

percentiles 求百分比

查看官方文档时候,没看懂,下面是自己测试时的例子,按照性别(F,M)查看工资范围的百分比

f2940af480e1b4b65ede0eee02de2ab9.png

{

"size": 0,

"aggs": {

"states": {

"terms": {

"field": "gender"

},

"aggs": {

"banlances": {

"percentile_ranks": {

"field": "balance",

"values": [

20000,

40000

]

}

}

}

}

}

f2940af480e1b4b65ede0eee02de2ab9.png

结果:

20180110223510038275.png

stats 统计

查看balance的统计情况:

f2940af480e1b4b65ede0eee02de2ab9.png

{

"size": 0,

"aggs": {

"balance_stats": {

"stats": {

"field": "balance"

}

}

}

}

f2940af480e1b4b65ede0eee02de2ab9.png

返回结果:

20180110223510040228.png

extended_stats 扩展统计

f2940af480e1b4b65ede0eee02de2ab9.png

{

"size": 0,

"aggs": {

"balance_stats": {

"extended_stats": {

"field": "balance"

}

}

}

}

f2940af480e1b4b65ede0eee02de2ab9.png

结果:

20180110223510041205.png

更加复杂的查询,后续慢慢在实践中道来。

Terms聚合

记录有多少F,多少M

f2940af480e1b4b65ede0eee02de2ab9.png

{

"size": 0,

"aggs": {

"genders": {

"terms": {

"field": "gender"

}

}

}

}

f2940af480e1b4b65ede0eee02de2ab9.png

返回结果如下:m记录507条,f记录493条

20180110223510044134.png

数据的不确定性

使用terms聚合,结果可能带有一定的偏差与错误性。

比如:

我们想要获取name字段中出现频率最高的前5个。

此时,客户端向ES发送聚合请求,主节点接收到请求后,会向每个独立的分片发送该请求。

分片独立的计算自己分片上的前5个name,然后返回。当所有的分片结果都返回后,在主节点进行结果的合并,再求出频率最高的前5个,返回给客户端。

这样就会造成一定的误差,比如最后返回的前5个中,有一个叫A的,有50个文档;B有49。 但是由于每个分片独立的保存信息,信息的分布也是不确定的。 有可能第一个分片中B的信息有2个,但是没有排到前5,所以没有在最后合并的结果中出现。 这就导致B的总数少计算了2,本来可能排到第一位,却排到了A的后面。

size与shard_size

为了改善上面的问题,就可以使用size和shard_size参数。

size参数规定了最后返回的term个数(默认是10个)

shard_size参数规定了每个分片上返回的个数

如果shard_size小于size,那么分片也会按照size指定的个数计算

通过这两个参数,如果我们想要返回前5个,size=5;shard_size可以设置大于5,这样每个分片返回的词条信息就会增多,相应的误差几率也会减小。

order排序

order指定了最后返回结果的排序方式,默认是按照doc_count排序。

f2940af480e1b4b65ede0eee02de2ab9.png

{

"aggs" : {

"genders" : {

"terms" : {

"field" : "gender",

"order" : { "_count" : "asc" }

}

}

}

}

f2940af480e1b4b65ede0eee02de2ab9.png

也可以按照字典方式排序:

f2940af480e1b4b65ede0eee02de2ab9.png

{

"aggs" : {

"genders" : {

"terms" : {

"field" : "gender",

"order" : { "_term" : "asc" }

}

}

}

}

f2940af480e1b4b65ede0eee02de2ab9.png

当然也可以通过order指定一个单值聚合,来排序。

f2940af480e1b4b65ede0eee02de2ab9.png

{

"aggs" : {

"genders" : {

"terms" : {

"field" : "gender",

"order" : { "avg_balance" : "desc" }

},

"aggs" : {

"avg_balance" : { "avg" : { "field" : "balance" } }

}

}

}

}

f2940af480e1b4b65ede0eee02de2ab9.png

同时也支持多值聚合,不过要指定使用的多值字段:

f2940af480e1b4b65ede0eee02de2ab9.png

{

"aggs" : {

"genders" : {

"terms" : {

"field" : "gender",

"order" : { "balance_stats.avg" : "desc" }

},

"aggs" : {

"balance_stats" : { "stats" : { "field" : "balance" } }

}

}

}

}

f2940af480e1b4b65ede0eee02de2ab9.png

返回结果:

20180110223510047064.png

min_doc_count与shard_min_doc_count

聚合的字段可能存在一些频率很低的词条,如果这些词条数目比例很大,那么就会造成很多不必要的计算。

因此可以通过设置min_doc_count和shard_min_doc_count来规定最小的文档数目,只有满足这个参数要求的个数的词条才会被记录返回。

通过名字就可以看出:

min_doc_count:规定了最终结果的筛选

shard_min_doc_count:规定了分片中计算返回时的筛选

script

桶聚合也支持脚本的使用:

f2940af480e1b4b65ede0eee02de2ab9.png

{

"aggs" : {

"genders" : {

"terms" : {

"script" : "doc[‘gender‘].value"

}

}

}

}

f2940af480e1b4b65ede0eee02de2ab9.png

以及外部脚本文件:

f2940af480e1b4b65ede0eee02de2ab9.png

{

"aggs" : {

"genders" : {

"terms" : {

"script" : {

"file": "my_script",

"params": {

"field": "gender"

}

}

}

}

}

}

f2940af480e1b4b65ede0eee02de2ab9.png

filter

filter字段提供了过滤的功能,使用两种方式:include可以匹配出包含该值的文档,exclude则排除包含该值的文档。

例如:

{

"aggs" : {

"tags" : {

"terms" : {

"field" : "tags",

"include" : ".*sport.*",

"exclude" : "water_.*"

}

}

}

}

上面的例子中,最后的结果应该包含sport并且不包含water。

也支持数组的方式,定义包含与排除的信息:

{

"aggs" : {

"JapaneseCars" : {

"terms" : {

"field" : "make",

"include" : ["mazda", "honda"]

}

},

"ActiveCarManufacturers" : {

"terms" : {

"field" : "make",

"exclude" : ["rover", "jensen"]

}

}

}

}

多字段聚合

通常情况,terms聚合都是仅针对于一个字段的聚合。因为该聚合是需要把词条放入一个哈希表中,如果多个字段就会造成n^2的内存消耗。

不过,对于多字段,ES也提供了下面两种方式:

1 使用脚本合并字段

2 使用copy_to方法,合并两个字段,创建出一个新的字段,对新字段执行单个字段的聚合。

collect模式

对于子聚合的计算,有两种方式:

depth_first 直接进行子聚合的计算

breadth_first 先计算出当前聚合的结果,针对这个结果在对子聚合进行计算。

默认情况下ES会使用深度优先,不过可以手动设置成广度优先,比如:

{

"aggs" : {

"actors" : {

"terms" : {

"field" : "actors",

"size" : 10,

"collect_mode" : "breadth_first"

},

"aggs" : {

"costars" : {

"terms" : {

"field" : "actors",

"size" : 5

}

}

}

}

}

}

缺省值Missing value

缺省值指定了缺省的字段的处理方式:

{

"aggs" : {

"tags" : {

"terms" : {

"field" : "tags",

"missing": "N/A"

}

}

}

}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/502293.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

div字体居中_div和span的使用

这节我们来制作以下效果我们先把四个段落的文字都写出来,分别包含在p标签里现在看到的效果如下我们来一点一点给它加入样式首先,来使文字水平居中并且加背景色但是这样显示的效果有一些问题,直接加入文字背景会显示背景顶着两头,导…

dubbo协议_Dubbo协议解析与OPPO自研ESA RPC框架实践

本文来自OPPO互联网基础技术团队,转载请注名作者。同时欢迎关注我们的公众号:OPPO_tech,与你分享OPPO前沿互联网技术及活动。1. 背景Dubbo是一款高性能、轻量级的开源Java RPC框架,诞生于2012年,2015年停止研发&#x…

fastjson反序列化过滤字段属性_原创干货 | 从RMI入门到fastjson反序列化RCE

关注我,让我成为你的专属小太阳吧RMI入门什么是RMIRMI(Remote Method Invocation)为远程方法调用,是允许运行在一个Java虚拟机的对象调用运行在另一个Java虚拟机上的对象的方法。这两个虚拟机可以是运行在相同计算机上的不同进程中,也可以是运…

axure web组件下载_Element - 饿了么团队出品的神级桌面 UI 组件库

一套著名的桌面端的组件库,同时提供Sketch、Axure模板资源文件方便快速产品设计。 介绍由饿了么团队出品,一套为开发者、设计师和产品经理准备的组件库,提供了配套axure、sektch设计资源,可以直接下载使用,能帮我等搬砖…

三农电子商务创业创新大赛作品_全国大学生电子商务“创新、创意及创业”挑战赛五邑大学校赛...

大赛简介第十届全国大学生电子商务“创新、创意及创业”挑战赛(简称“三创赛”)是由全国电子商务创新产教联盟主办,由“三创赛”竞赛组织委员会统一策划、组织、管理与实施。“三创赛”由校赛、省赛和国赛三级竞赛组成,分别由教育部认可的全国高校提出申…

程序员的数学 pdf_作为一个程序员,分享我日常学习方式,自学渠道和方式

做了几年程序员,只有高中学生的基础,就做不了高等数学算法相关工作,在有限的技术领域里进行自学做自己能做的业务。学习是少不了的事情,每天一大部分时间都是处于自学状态。第一个平台是慕课网,从高中毕业开始看慕课网…

apache2 wordpress目录权限_小白指南:WordPress中的用户角色和权限

WordPress本身自带了一套用户角色管理系统,这套系统定义了每个用户角色可以做什么,不可以做什么。随着网站的发展,弄懂这些用户角色和权限的问题是非常有必要的。在这篇小白指南中,我们将用图表的形式对比WordPress中每个用户角色…

mysql分区概念_mysql的分区

在mysql 5.1.3之后引入和partition(分区)的概念。这个是个好东东。以前遇到一个大表的时候,我们会手动将其分为几个小表(就是分表操作)。但是分表操作有几个缺点:1 麻烦,这里指的麻烦是不仅对于调用分表的sql语句的处理上,也是分表…

pytest测试实战pdf_Pytest+Allure美化测试报告

今日推荐音乐:我最爱的霉霉在学习pytest的时候,生成的html报告觉得实在不是很美观,查到资料有很多测试报告的第三方插件,不仅美观而且查看测试用例也很方便,那我们一起来学习下吧~0 1参考案例要学习一个新技术&#xf…

java 递归_采用递归算法求解迷宫问题(Java版) | 附代码+视频

递归算法能够解决很多计算机科学问题,迷宫问题就是其中一个典型案例。本篇教程我们将采用递归算法求解迷宫问题,输出从入口到出口的所有迷宫路径。01用递归算法解决迷宫问题迷宫问题在《数据结构教程》第3章介绍过,设mgpath(int xi&#xff0…

挂机宝装mysql_挂机宝安装

万安挂机宝下载后安装包里有介绍.proxydroid使用说明以雷电模拟器为例永久记住选择 允许 (安卓手机 需要 root 方可使用)设置 账号密码启动即可 下面是详细翻译说明一、下载ProxyDroid。二、对ProxyDroid进行配置(基本配置:)(1) Auto Setting不勾选,我们…

python爬虫是数据挖掘吗_爬虫属于数据挖掘 python为什么叫爬虫

数据挖掘和爬虫有区别吗?数据挖掘和爬虫有很大的区别。数据挖掘过程应用于爬虫的可能性并不是特别大,但所占比例相对较大。但是使用爬虫,一般来说,爬虫都是爬到别人的网站上的,而且有些规则。因此,从数据挖…

通过代理上网 固定ip_浅析局部代理IP与全局代理IP的使用说明

经常有人问,如何设置局部代理IP,如何设置全局代理IP,今天我们一起来看看。何谓局部代理IP,顾名思义,改变局部的IP,不影响其他程序软件运行的使用IP;所谓全局代理IP,就是改变整个客户…

如何检查私钥和公钥是否配对_如何检查家具是否有臭虫

如果您购买了二手家具,或者家具使用好多年了,那么由于家庭环境等问题,难免会出现臭虫!臭虫可以通过许多不同的方式进入您的房屋,但是最常见的方法之一是您的二手家具。关于臭虫首先,让我们从臭虫入门。这些…

利用expect安装mysql_linux使用mysqldump+expect+crontab实现mysql周期冷备份思路详解

一、遇到的问题我们使用过mysqldump都知道,使用该命令后,需要我们手动输入 mysql的密码,那么我们就不能够直接在crontab中使用mysqldump实现周期备份。其实我们可以使用expect脚本自动输入密码,从而实现真正的周期备份。如果你不知…

数据结构实验之图论九:最小生成树_初高中数学竞赛训练----图论初步2

例题中有2019年罗马尼亚大师赛第3试题树树:一个连通图,如果没有一个环,则叫树。森林:若干个独立的树形成一个森林。链:一个特殊的树是节点中,除去两个节点的度为1,其它均为2,叫做链。…

在每个运行中运行多个查询_Spring Data JPA的运行原理及几种查询方式

Spring Data JPA的运行原理:PersistenceContext(name"entityManagerFactory") private EntityManager em; Test public void test1(){ //org.springframework.data.jpa.repository.support.SimpleJpaRepositor yfba8bf //System.out.println(this.u…

467python教程_Magnus Lie Hetland的《Python基础教程(第3版)》自学笔记(持续更新中)...

转载请注明原创出处,谢谢!如果读完觉得有收获的话,欢迎点赞加关注。Python基础教程.jpg快速上手:基础知识交互式解释器在Python交互式解释器的提示符>>>后面输入help()可以获取指南,在IDLE中,还可…

java 获取所有带指定注解的类名_SXT DAY023 反射和注解

1. 反射机制介绍_Class对象获取反射机制是 Java 的动态性之一 动态语言:在程序运行时,可以改变程序的结构或变量的 类型。反射机制的常见作用动态的加载类、动态的获取类的信息(属性,方法,构造 器) 动态构造对象 动态调用类和对象的任意方法、…

tomcat勾连mysql_tomcat9.0启动脚本startup.bat的分析

1、 Apache Tomcat的下载和安装从Apache官网https://tomcat.apache.org/可以下载各种版本的tomcat软件,下载的文件格式可以是zip/tar.gz/exe形式的。如下图所示,在64位windows中使用tomcat,我们可以下载"64-bit Windows.zip",直接解…