自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

又談SQL-to-SQL翻譯器

運(yùn)維 數(shù)據(jù)庫運(yùn)維
在轉(zhuǎn)換過程中,我們引用了DSL,來承接前面的SQL解析,以及后續(xù)的SQL生成,于是,自然的將轉(zhuǎn)換分成了2段,即輸入轉(zhuǎn)換(SourceMapper) 和 輸出轉(zhuǎn)換(SinkMapper)而定義轉(zhuǎn)換與否,以及轉(zhuǎn)換動如何完成,我們可以輕松的通過java自帶的 Function 接口來實(shí)現(xiàn)。

[[391967]]

這次從一張圖說起,就是下面這幅圖,當(dāng)我畫完他的時(shí)候,我就感覺無比的舒爽。讓整個(gè)執(zhí)行流程,可控,并且可擴(kuò)展。還記得當(dāng)初上學(xué)的時(shí)候,數(shù)學(xué)建模課上,老師為了“求證一張四條腿的椅子,四條腿處在一個(gè)平面上的概率”,寫了滿滿四黑板板書,然后心滿意足的,跟一臉蒙的我們說,“看,多美啊!”。我現(xiàn)在有點(diǎn)理解他當(dāng)時(shí)的狀態(tài)了。

有眼尖的同學(xué),可能已經(jīng)發(fā)現(xiàn)了,沒錯(cuò),這里借鑒了Flink的流程設(shè)計(jì)。

簡單的說,輸入-> 轉(zhuǎn)換 -> 輸出 經(jīng)典的三段論式構(gòu)造。

這里我們把輸入 SourceFunction 和 輸出 SinkFunction 進(jìn)行了抽象,但是并沒有像Flink那樣,輸入輸出集成相同的接口,可以自由轉(zhuǎn)換,從需求上來看,是沒有必要Sql -to- Sql -to- Sql 的必要的。

在轉(zhuǎn)換過程中,我們引用了DSL,來承接前面的SQL解析,以及后續(xù)的SQL生成,于是,自然的將轉(zhuǎn)換分成了2段,即輸入轉(zhuǎn)換(SourceMapper) 和 輸出轉(zhuǎn)換(SinkMapper)

而定義轉(zhuǎn)換與否,以及轉(zhuǎn)換動如何完成,我們可以輕松的通過java自帶的 Function 接口來實(shí)現(xiàn)。

一個(gè)輸入是可以接對接N條輸出的,輸出的方向也完全由實(shí)現(xiàn) SinkFunction 的對象來自實(shí)現(xiàn)。

如果后續(xù),把任務(wù)并行化,Pipline 對外提供高階函數(shù)的話, 畫美不看...

DEMO:

  1. public static void main(String[] args) throws IOException { 
  2.       //輸入 
  3.       FileSourceFunction fileSourceFunction = new FileSourceFunction(); 
  4.       fileSourceFunction.init(new File("fff.txt")); 
  5.  
  6.       //輸出 
  7.       PrintlnSinkFunction<PrintStream> printSinkFunction = new PrintlnSinkFunction(); 
  8.       ListSinkFunction listSinkFunction = new ListSinkFunction(); 
  9.  
  10.  
  11. ansformPepline tp = new TransformPepline(); 
  12.   //添加輸入輸出 
  13. .addSource(fileSourceFunction) 
  14.               .addSink(printSinkFunction) 
  15.               .addSink(listSinkFunction); 
  16.   //定制轉(zhuǎn)換動作 
  17.       tp.addSourceMapFunction(new Function<String, String>() { 
  18.           SqlTransExecManager sqlTransExecManager = new SqlTransExecManager().build(); 
  19.           @Override 
  20.           public String apply(String s) { 
  21.               return sqlTransExecManager.doParseAndTransform(s).getTargetSql(); 
  22.           } 
  23.       }); 
  24.       //執(zhí)行 
  25.       tp.execute(); 
  26.       System.out.println(listSinkFunction.getLists()); 
  27.   } 

本文轉(zhuǎn)載自微信公眾號「麒思妙想」,可以通過以下二維碼關(guān)注。轉(zhuǎn)載本文請聯(lián)系麒思妙想公眾號。

 

責(zé)任編輯:武曉燕 來源: 麒思妙想
相關(guān)推薦

2020-12-09 05:24:28

SQL翻譯器程序

2016-12-21 08:40:53

微軟萬能翻譯器

2023-08-07 08:00:00

開源ChatGPTSQL

2010-09-27 15:36:48

2023-05-25 14:10:54

AI人工智能

2011-03-15 17:36:24

SQL Server數(shù)據(jù)遷移云端

2010-09-03 13:21:01

SQL刪除

2017-08-31 12:07:52

微軟

2009-06-10 09:16:05

Bing在線翻譯Google在線翻譯比較

2020-06-12 14:40:45

開源技術(shù) 翻譯

2021-08-26 15:05:01

微軟翻譯文言文微軟亞洲研究院

2010-09-27 10:55:01

SQL事件探查器

2009-05-06 17:31:17

SQL EnlightT-SQL分析器

2010-06-18 09:55:06

SQL Server

2011-03-28 10:05:57

sql觸發(fā)器代碼

2009-09-08 14:45:24

Linq to SQL支持SQL Serve

2017-08-31 16:17:35

SQL優(yōu)化器原理

2010-11-08 11:53:16

2010-11-09 14:47:46

SQL Server跨
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號