kettle入门教程

@Test
public void read() throws KettleException {
KettleEnvironment.init();

TransMeta transMeta = new TransMeta();
transMeta.setName("datesyn2");

//添加数据连接
DatabaseMeta dataBaseInput = new DatabaseMeta("Input", "Mysql", "Native(JDBC)", "192.168.1.187", "tdir", "3306",
"root", "root");

transMeta.addDatabase(dataBaseInput);

//表输入
TableInputMeta tableInputMeta = new TableInputMeta();
tableInputMeta.setDatabaseMeta(transMeta.findDatabase("Input"));
tableInputMeta.setSQL("SELECT id, name, age FROM test");

StepMeta inputStep = new StepMeta("表输入",tableInputMeta);
inputStep.setLocation(50,50);
// inputStep.setDraw(true);
transMeta.addStep(inputStep);
inputStep.setDraw(true);

String xml =transMeta.getXML();
DataOutputStream dos = new DataOutputStream(KettleVFS.getOutputStream("D:/csv.ktr", false));
try {
dos.write(xml.getBytes(Const.XML_ENCODING));
dos.close();
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}

//开始执行
Trans trans = new Trans(transMeta);
trans.prepareExecution(null);

trans.startThreads();
trans.waitUntilFinished();

if(trans.getErrors() > 0) {
System.out.println(">>>>>>>>>> ERROR");
}else {
System.out.println(">>>>>>>>>> SUCCESS ");
}
}
posted @ 2019-01-07 18:23  hsyooy  阅读(532)  评论(0编辑  收藏  举报