flinksql获取系统当前时间搓_java-flinksql:在纯SQL语法中使用时间戳 join表

我在使用Flink的SQL语法 join多个表时遇到了一些问题,因为其中至少有一个表具有time属性列。

当tabletime的值为rowtime时,使用的是表1。

我想用一个使用模式(id,value2)的Table2 join这个表。 join必须在匹配的id上完成。

最后,我想用一个翻滚的时间窗口对这个 join的结果进行分组。

是否可以只使用SQL语法来实现这一点?

下面是我想做的一个例子:

SELECT

Table1.id as id,

TUMBLE_END(rowtime, INTERVAL '10' SECOND),

MAX(value1) as value1,

MAX(value2) as value2

FROM Table1 JOIN TABLE2 ON Table1.id = Table2.id

GROUP BY Table1.id, TUMBLE(rowtime, INTERVAL '10' SECOND)

但它给了我以下错误:

2019-11-12 16:37:57.191 [main] ERROR - Cannot generate a valid execution plan for the given query:

FlinkLogicalCalc(expr#0..6=[{inputs}], id=[$t0], EXPR$1=[$t4], value1=[$t1], value2=[$t2])

FlinkLogicalWindowAggregate(group=[{0}], value1=[MAX($2)], value2=[MAX($3)])

FlinkLogical

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值