一、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)-窗口&聚合分组的更多相关文章

  1. PB gird类型数据窗口 设置分组、分组小计、合计

    今天遇到一个需求,gird表格数据如下:  部门  类型 数据   A  类型1  1  A  类型2  2  B  类型1  3  B  类型2  4   合计 10 实际需要显示的结果为:  部门 ...

  2. 【高德地图API】从零开始学高德JS API(三)覆盖物——标注|折线|多边形|信息窗口|聚合marker|麻点图|图片覆盖物

    原文:[高德地图API]从零开始学高德JS API(三)覆盖物——标注|折线|多边形|信息窗口|聚合marker|麻点图|图片覆盖物 摘要:覆盖物,是一张地图的灵魂.有覆盖物的地图,才是完整的地图.在 ...

  3. Django之ORM操作(聚合 分组、F Q)

    Django之ORM操作(聚合 分组.F Q) 聚合 aggregate()是QuerySet的一个终止子句,也就是说,他返回一个包含一些键值对的字典,在它的后面不可以再进行点(.)操作.   键的名 ...

  4. day056-58 django多表增加和查询基于对象和基于双下划线的多表查询聚合 分组查询 自定义标签过滤器 外部调用django环境 事务和锁

    一.多表的创建 from django.db import models # Create your models here. class Author(models.Model): id = mod ...

  5. Django day08 多表操作 (五) 聚合,分组查询 和 F,Q查询

    一:聚合,分组查询 二:F, Q查询

  6. MySql 筛选条件、聚合分组、连接查询

    筛选条件 比较运算符 等于: = ( 注意!不是 == ) 不等于: != 或 <> 大于: > 大于等于: >= 小于: < 小于等于: <= IS NULL I ...

  7. 数据聚合 & 分组:新一代系统监控的核心功能

    遥想 2015 年 8 月 17 日,Cloud Insight 还在梳理功能原型,畅想 Cloud Insight 存在的意义:为什么阿里云用户需要使用 Cloud Insight 来加强管理. 而 ...

  8. SQL你必须知道的-查询聚合分组排序

    use MySchoolTwo    -- 简单查询    select * from Student    -- 话说这种查询的效率要比 * 要高级点    select sId , sName , ...

  9. MongoDB 聚合分组取第一条记录的案例及实现

    关键字:MongoDB: aggregate:forEach 今天开发同学向我们提了一个紧急的需求,从集合mt_resources_access_log中,根据字段refererDomain分组,取分 ...

随机推荐

  1. JavaScript中的匿名函数及函数的闭包(转)

    JavaScript中的匿名函数及函数的闭包  https://www.cnblogs.com/wl0000-03/p/6050108.html 1.匿名函数 函数是JavaScript中最灵活的一种 ...

  2. SQL获取时间戳流水号

    流水号生成规则: 1:流水号总长度为22位数 2:流水号总共分三部分:标头(2位)+ 时间戳(YYYYMMDDHHmmSSsss共17位)+ 随机码(3位) 举例流水号:SN2015081210240 ...

  3. cakephp静态资源404

    location ~ /\.(css|js|woff|ttf|gif|jpg|jpeg|png|bmp|swf) { rewrite ^/$/(.*)$ /$/app/webroot/$ last; ...

  4. 《Effective Java》第3章 对于所有对象都通用的方法

    第8条:覆盖equals时请遵守通用约定 覆盖equals方法看起来似乎很简单,但是有许多覆盖方式会导致错误,并且后果非常严重.最容易避免这类问题的办法就是不覆盖equals方法,在这种情况下,类的每 ...

  5. Spring @ResponseBody 返回乱码 的优雅解决办法

    版权声明:本文为博主原创文章,未经博主允许不得转载. 目录(?)[+] 返回的结果中,中文全部被问号(?)代替的解决办法: *-servlet.xml的部分配置如下: <bean id=&quo ...

  6. asp 控件定时器 局部刷新

    <asp:ScriptManager ID="ScriptManager1" runat="server" /> <asp:UpdatePan ...

  7. c#处理未捕获的异常(UnhandledException)

    处理未捕获的异常,放在program类的Main函数下 1.UnhandledException 作用:接收未捕获到的异常 例: static void Main(string[] args) { A ...

  8. Unity中Awake的执行时间点

    https://docs.unity3d.com/ScriptReference/MonoBehaviour.Awake.html 根据官方文档,Awake的实际执行点,应该是对应mono脚本所在物体 ...

  9. Locust学习总结分享

    简介: Locust是一个用于可扩展的,分布式的,性能测试的,开源的,用Python编写框架/工具,它非常容易使用,也非常好学.它的主要思想就是模拟一群用户将访问你的网站.每个用户的行为由你编写的py ...

  10. JavaScript 测试和捕捉(try与catch)

    JavaScript 测试和捕捉 try 语句允许我们定义在执行时进行错误测试的代码块. catch 语句允许我们定义当 try 代码块发生错误时,所执行的代码块. JavaScript 语句 try ...