sqoop 抽取源码流程分析( 三 ) 代码生成工具分析

1. 工具的作用

根据数据库 Schema 信息生成一个java文件,并编译打包。

2. 继承关系


public class CodeGenTool extends com.cloudera.sqoop.tool.BaseSqoopTool {

可以看出,基本上所有的工具类都从BaseSqoopTool 继承3而来,具体的关系,已经在ImportTool 工具的代码分析中讲过。

3. 工具类的run 方法

  @Override

  /** {@inheritDoc} */

  public int run(SqoopOptions options) {

......


   generateORM(options, options.getTableName());

.....


3.1 generateORM 的具体实现

 public String generateORM(SqoopOptions options, String tableName)

      throws IOException {

......

    CompilationManager compileMgr = new CompilationManager(options);

    ClassWriter classWriter = new ClassWriter(options, manager, tableName, compileMgr);

    classWriter.generate();

    compileMgr.compile();

    compileMgr.jar();
......

3.2 代码生成 ClassWriter

这个部分主要是根据数据库的元数据信息进行

3.3 代码编译 CompilationManager

这个部分主要是对刚刚生成的代码进行编译的,具体细节请去看源码,这里暂时忽略

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值