esper(3)-窗口&聚合分组
一、Insert and Remove Stream
1、
select * from com.ebc.updatelistener.User
只输出newEvents,不会输出oldEvents。即使加上isstream,也不会。
2、
select irstream * from com.ebc.updatelistener.User.win:length(5)
当达到第6个时,第1个会成为oldEvents。如果去掉irstream,则不会产生oldEvents。
二、Filter and Where-Clause
Filter:
select * from com.ebc.filterwhere.User(amount>=200).win:length(5)
where:
select * from com.ebc.filterwhere.User.win:length(5) where amount>=200
filter: 只有符合条件的event才进入view和触发updateListener。
where:所有event都会进入view,只有符合条件的event才触发updateListener。
三、聚合与分组
1、sum
//统计进入的5个event的总额
select sum(amount) from com.ebc.aggGroup.User.win:length_batch(5) --UpdateListener
Integer sumV = (Integer) (newEvents[0].get("sum(amount)"));
2、groupby
初始数据
--view
class User implements Serializable {
private String name;
private int age;
private int amount;
}
--事件
runtime.sendEvent(new User("遥远1",1,1));
runtime.sendEvent(new User("遥远2",2,2));
runtime.sendEvent(new User("遥远1",3,3));
runtime.sendEvent(new User("遥远2",4,4));
runtime.sendEvent(new User("遥远1",5,5));
runtime.sendEvent(new User("遥远6",6,6));
情况1:
--epl
select name,sum(amount) from com.ebc.aggGroup.User.win:length_batch(5) group by name
--输出
name=遥远2,sumV=6
name=遥远1,sumV=9
情况2:
--epl
select name,sum(amount),age from com.ebc.aggGroup.User.win:length_batch(5) group by name
--输出
name=遥远1,sumV=9,age=1
name=遥远2,sumV=6,age=2
name=遥远1,sumV=9,age=3
name=遥远2,sumV=6,age=4
name=遥远1,sumV=9,age=5
情况3:
--epl
select name,sum(amount),age from com.ebc.aggGroup.User.win:length_batch(5) group by name,age
--输出
name=遥远1,sumV=1,age=1
name=遥远2,sumV=2,age=2
name=遥远1,sumV=3,age=3
name=遥远1,sumV=5,age=5
name=遥远2,sumV=4,age=4
如果情况3的epl不变,修改发送数据,即红色部分
runtime.sendEvent(new User("遥远1",1,1));
runtime.sendEvent(new User("遥远2",2,2));
runtime.sendEvent(new User("遥远1",,3));
runtime.sendEvent(new User("遥远2",4,4));
runtime.sendEvent(new User("遥远1",,5));
runtime.sendEvent(new User("遥远6",6,6));
则输出
name=遥远1,sumV=9,age=1
name=遥远2,sumV=2,age=2
name=遥远2,sumV=4,age=4
group by总结
--只对name分组来sum,age不参与
select name,sum(amount),age from com.ebc.aggGroup.User.win:length_batch(5) group by name --对name、age分组来sum
select name,sum(amount),age from com.ebc.aggGroup.User.win:length_batch(5) group by name,age
esper(3)-窗口&聚合分组的更多相关文章
- PB gird类型数据窗口 设置分组、分组小计、合计
今天遇到一个需求,gird表格数据如下: 部门 类型 数据 A 类型1 1 A 类型2 2 B 类型1 3 B 类型2 4 合计 10 实际需要显示的结果为: 部门 ...
- 【高德地图API】从零开始学高德JS API(三)覆盖物——标注|折线|多边形|信息窗口|聚合marker|麻点图|图片覆盖物
原文:[高德地图API]从零开始学高德JS API(三)覆盖物——标注|折线|多边形|信息窗口|聚合marker|麻点图|图片覆盖物 摘要:覆盖物,是一张地图的灵魂.有覆盖物的地图,才是完整的地图.在 ...
- Django之ORM操作(聚合 分组、F Q)
Django之ORM操作(聚合 分组.F Q) 聚合 aggregate()是QuerySet的一个终止子句,也就是说,他返回一个包含一些键值对的字典,在它的后面不可以再进行点(.)操作. 键的名 ...
- day056-58 django多表增加和查询基于对象和基于双下划线的多表查询聚合 分组查询 自定义标签过滤器 外部调用django环境 事务和锁
一.多表的创建 from django.db import models # Create your models here. class Author(models.Model): id = mod ...
- Django day08 多表操作 (五) 聚合,分组查询 和 F,Q查询
一:聚合,分组查询 二:F, Q查询
- MySql 筛选条件、聚合分组、连接查询
筛选条件 比较运算符 等于: = ( 注意!不是 == ) 不等于: != 或 <> 大于: > 大于等于: >= 小于: < 小于等于: <= IS NULL I ...
- 数据聚合 & 分组:新一代系统监控的核心功能
遥想 2015 年 8 月 17 日,Cloud Insight 还在梳理功能原型,畅想 Cloud Insight 存在的意义:为什么阿里云用户需要使用 Cloud Insight 来加强管理. 而 ...
- SQL你必须知道的-查询聚合分组排序
use MySchoolTwo -- 简单查询 select * from Student -- 话说这种查询的效率要比 * 要高级点 select sId , sName , ...
- MongoDB 聚合分组取第一条记录的案例及实现
关键字:MongoDB: aggregate:forEach 今天开发同学向我们提了一个紧急的需求,从集合mt_resources_access_log中,根据字段refererDomain分组,取分 ...
随机推荐
- SQL 连贯操作 [2]
1.alias 用于设置数据表别名 $user = M('User'); var_dump($user->alias('anothername')->select()); 这时在SQL中的 ...
- Condition实现多线程顺序打印
Condition实现多线程顺序打印: import java.util.concurrent.locks.Condition; import java.util.concurrent.locks.R ...
- 时间获取_Date\SimpleDateFormat\Calendar类
1.获取当前的日期,并把这个日期转换为指定格式的字符串,如2088-08-08 08:08:08 import java.text.SimpleDateFormat; import java.uti ...
- ubuntu nvidia驱动+cuda9.0
https://blog.csdn.net/fdqw_sph/article/details/78745375
- js/jq基础(日常整理记录)-1-纯js格式化时间
一.纯js格式化时间 之前记录了一些,工作中发现的比较常用的使用,就记录一下. 由于很基础,就直接贴出来了,不做分析了. 改造一下Date的原型 Date.prototype.format = fun ...
- vs2010 怎样设置文本编辑窗口和解决方案资源管理器同步?
即切换左边的文本编辑窗口,解决方案资源管理器如何定位到相应的文件项上?答案: 工具--选项--项目和解决方案--常规--在解决方案资源管理器中跟踪活动项(前打勾)确定 应该就可以了.
- FlowLayoutPanel控件控制里面子控件换行
// 摘要: // 设置值,该值表示的流中断设置 System.Windows.Forms.FlowLayoutPanel 控件. // // 参数: // control: // 子控件. // / ...
- Aspose.Words CookieBook
Aspose.Words.dll 版本 13.1.0.0 [原创]Aspose.Words组件介绍及使用—基本介绍与DOM概述 插入分页符 DocumentBuilder builder = new ...
- [SinGuLaRiTy] 图论题目复习
[SInGuLaRiTy-1027] Copyright (c) SinGuLaRiTy 2017. All Rights Reserved. [Vijos 1423] 最佳路线 题目描述 年久失修的 ...
- Java开发环境配置(JDK+Tomcat+MyEclipsed)
前言 这个项目一开始,我只能说我把自己整的很无语,所以我只能在调整心态的基础上,重新把思路缕了一遍,好了,接下来就说java运行环境以及发布运行方法还有SSH环境配置. 内容 本次配置用到的安装包: ...