又谈SQL-to-SQL翻译器

运维 数据库运维
在转换过程中,我们引用了DSL,来承接前面的SQL解析,以及后续的SQL生成,于是,自然的将转换分成了2段,即输入转换(SourceMapper) 和 输出转换(SinkMapper)而定义转换与否,以及转换动如何完成,我们可以轻松的通过java自带的 Function 接口来实现。

[[391967]]

这次从一张图说起,就是下面这幅图,当我画完他的时候,我就感觉无比的舒爽。让整个执行流程,可控,并且可扩展。还记得当初上学的时候,数学建模课上,老师为了“求证一张四条腿的椅子,四条腿处在一个平面上的概率”,写了满满四黑板板书,然后心满意足的,跟一脸蒙的我们说,“看,多美啊!”。我现在有点理解他当时的状态了。

有眼尖的同学,可能已经发现了,没错,这里借鉴了Flink的流程设计。

简单的说,输入-> 转换 -> 输出 经典的三段论式构造。

这里我们把输入 SourceFunction 和 输出 SinkFunction 进行了抽象,但是并没有像Flink那样,输入输出集成相同的接口,可以自由转换,从需求上来看,是没有必要Sql -to- Sql -to- Sql 的必要的。

在转换过程中,我们引用了DSL,来承接前面的SQL解析,以及后续的SQL生成,于是,自然的将转换分成了2段,即输入转换(SourceMapper) 和 输出转换(SinkMapper)

而定义转换与否,以及转换动如何完成,我们可以轻松的通过java自带的 Function 接口来实现。

一个输入是可以接对接N条输出的,输出的方向也完全由实现 SinkFunction 的对象来自实现。

如果后续,把任务并行化,Pipline 对外提供高阶函数的话, 画美不看...

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.   //定制转换动作 
  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.       //执行 
  25.       tp.execute(); 
  26.       System.out.println(listSinkFunction.getLists()); 
  27.   } 

本文转载自微信公众号「麒思妙想」,可以通过以下二维码关注。转载本文请联系麒思妙想公众号。

 

责任编辑:武晓燕 来源: 麒思妙想
相关推荐

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数据迁移云端

2010-09-03 13:21:01

SQL删除

2009-06-10 09:16:05

Bing在线翻译Google在线翻译比较

2010-09-27 10:55:01

SQL事件探查器

2009-05-06 17:31:17

SQL EnlightT-SQL分析器

2017-08-31 12:07:52

微软

2021-08-26 15:05:01

微软翻译文言文微软亚洲研究院

2020-06-12 14:40:45

开源技术 翻译

2010-06-18 09:55:06

SQL Server

2011-03-28 10:05:57

sql触发器代码

2010-06-18 09:08:29

SQL Server

2010-06-23 09:23:56

SQL Server

2010-09-26 14:21:43

sql跨服务器查询

2010-10-20 15:53:37

SQL Server服
点赞
收藏

51CTO技术栈公众号