ApacheFlink-テーブルAPIとSQL
テーブルAPIは、SQLのような式言語を使用するリレーショナルAPIです。このAPIは、バッチ処理とストリーム処理の両方を実行できます。JavaとScalaのデータセットおよびデータストリームAPIを組み込むことができます。既存のデータセットとデータストリーム、または外部データソースからテーブルを作成できます。このリレーショナルAPIを介して、結合、集約、選択、フィルタリングなどの操作を実行できます。入力がバッチであろうとストリームであろうと、クエリのセマンティクスは同じままです。
これがサンプルのTableAPIプログラムです-
// for batch programs use ExecutionEnvironment instead of StreamExecutionEnvironment
val env = StreamExecutionEnvironment.getExecutionEnvironment
// create a TableEnvironment
val tableEnv = TableEnvironment.getTableEnvironment(env)
// register a Table
tableEnv.registerTable("table1", ...) // or
tableEnv.registerTableSource("table2", ...) // or
tableEnv.registerExternalCatalog("extCat", ...)
// register an output Table
tableEnv.registerTableSink("outputTable", ...);
// create a Table from a Table API query
val tapiResult = tableEnv.scan("table1").select(...)
// Create a Table from a SQL query
val sqlResult = tableEnv.sqlQuery("SELECT ... FROM table2 ...")
// emit a Table API result Table to a TableSink, same for SQL result
tapiResult.insertInto("outputTable")
// execute
env.execute()