Apache Flink - टेबल एपीआई और एसक्यूएल

टेबल एपीआई अभिव्यक्ति की भाषा की तरह एसक्यूएल के साथ एक संबंधपरक एपीआई है। यह एपीआई बैच और स्ट्रीम प्रोसेसिंग दोनों कर सकता है। इसे जावा और स्काला डेटासेट और डेटास्ट्रीम एपीआई के साथ एम्बेड किया जा सकता है। आप मौजूदा डेटासेट और डेटास्ट्रीम से या बाहरी डेटा स्रोतों से टेबल बना सकते हैं। इस संबंधपरक एपीआई के माध्यम से आप ज्वाइन, एग्रीगेट, सिलेक्ट और फिल्टर जैसे ऑपरेशन कर सकते हैं। इनपुट चाहे बैच हो या स्ट्रीम, क्वेरी का शब्दार्थ समान रहता है।

यहाँ एक नमूना तालिका एपीआई कार्यक्रम है -

// 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()