我想加入一个大表,不可能包含在TM内存和流(kakfa)中。我成功地加入了我的测试,将 table-api 与 datastream api 混合在一起。我做了以下事情:
val stream: DataStream[MyEvent] = env.addSource(...)
stream
.timeWindowAll(...)
.trigger(...)
.process(new ProcessAllWindowFunction[MyEvent, MyEvent, TimeWindow] {
var tableEnv: StreamTableEnvironment = _
override def open(parameters: Configuration): Unit = {
//init table env
}
override def process(context: Context, elements: Iterable[MyEvent], out: Collector[MyEvent]): Unit = {
val table = tableEnv.sqlQuery(...)
elements.map(e => {
//do process
out.collect(...)
})
}
})
它正在工作,但我从未在任何地方看到过这种类型的实现。可以吗?有什么缺点?