如何解决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
“事件”是您的事件类型。您没有说出事件类型的名称。 “上一个”是上一个功能(请参见手册)。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。