Esper / NEsper EPL事件声明

问题描述

我是Esper新手。谁能帮助我定义EPL语句以在发生以下情况时捕获事件:

  • 假定存在具有3个属性的事件-(字符串)符号,(布尔)值,(日期时间)时间戳。例如,事件1(Symbol-apple,Value-true,Timestamp- 2020.10.07 14:00:00),事件2(Symbol-orange,Value-true,Timestamp- 2020.10.07 14:00:00)和event3(Symbol-香蕉,值错误,时间戳-2020.10.07 14:00:00)。如果它们具有相同(或几乎相同)的时间戳,则其中只有一个可以具有-值为true的属性。在此示例中,event2符合要求,应将其捕获。

如何定义要捕获的语句?

感谢您的帮助。

Narsu

解决方法

“窗口”是一个聚合函数(请参见手册)返回事件。枚举方法(selectfrom,countof,请参见手册)用于过滤和选择。像这样的东西。

select window(*).selectFrom(v => v.value=true) as eventWithTrueFlag
from Event#length(3) 
having window(*).countOf(v => v.value=true)=1 and 
  prev(1,timestamp)=timestamp and prev(2,timestamp)=timestamp

“事件”是您的事件类型。您没有说出事件类型的名称。 “上一个”是上一个功能(请参见手册)。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...