Kettle4 Repository 操作示例 (登陆资源库,获取模型,运行)

Java代码   收藏代码
  1. /** 
  2.  * Kettle 4.2.0 版本测试通过 
  3.  */  
  4. package zhangxin.test;  
  5.   
  6. import java.util.List;  
  7.   
  8. import org.pentaho.di.core.KettleEnvironment;  
  9. import org.pentaho.di.core.exception.KettleException;  
  10. import org.pentaho.di.core.plugins.PluginRegistry;  
  11. import org.pentaho.di.core.plugins.RepositoryPluginType;  
  12. import org.pentaho.di.repository.ObjectId;  
  13. import org.pentaho.di.repository.RepositoriesMeta;  
  14. import org.pentaho.di.repository.Repository;  
  15. import org.pentaho.di.repository.RepositoryElementMetaInterface;  
  16. import org.pentaho.di.repository.RepositoryMeta;  
  17. import org.pentaho.di.repository.StringObjectId;  
  18. import org.pentaho.di.trans.Trans;  
  19. import org.pentaho.di.trans.TransMeta;  
  20.   
  21. /** 
  22.  * 登陆资源库,获取模型,运行 
  23.  *  
  24.  * @author zhangxin 
  25.  *  
  26.  */  
  27. public class TestRepository {  
  28.   
  29.     /** 
  30.      * @param args 
  31.      * @throws KettleException 
  32.      */  
  33.     public static void main(String[] args) throws KettleException {  
  34.         // 运行环境初始化(设置主目录、注册必须的插件等)  
  35.         KettleEnvironment.init();  
  36.         RepositoriesMeta repositoriesMeta = new RepositoriesMeta();  
  37.         // 从文件读取登陆过的资源库信息  
  38.         repositoriesMeta.readData();  
  39.         // 选择登陆过的资源库  
  40.         RepositoryMeta repositoryMeta = repositoriesMeta.findRepository("4_2");  
  41.         // 获得资源库实例  
  42.         Repository repository = PluginRegistry.getInstance().loadClass(RepositoryPluginType.class, repositoryMeta.getId(), Repository.class);  
  43.         repository.init(repositoryMeta);  
  44.         // 连接资源库  
  45.         repository.connect("admin""admin");  
  46.         ObjectId id = new StringObjectId("0");  
  47.         // 获取某个资源库的所有转换  
  48.         List<RepositoryElementMetaInterface> li = repository.getTransformationObjects(id, false);  
  49.         TransMeta transMeta = null;  
  50.         if (li != null) {  
  51.             for (RepositoryElementMetaInterface repe : li) {  
  52.                 System.out.println("TRANSFORMATION:" + repe.getObjectId() + "name:" + repe.getName());  
  53.                 TransMeta tm = repository.loadTransformation(repe.getObjectId(), null);  
  54.                 if ("测试转换".equals(tm.getName())) {  
  55.                     transMeta = tm;  
  56.                 }  
  57.             }  
  58.         }  
  59.         // 执行指定转换  
  60.         Trans trans = new Trans(transMeta);  
  61.         trans.execute(null);  
  62.         trans.waitUntilFinished();  
  63.         if (trans.getErrors() > 0) {  
  64.             throw new RuntimeException("There were errors during transformation execution.");  
  65.         }  
  66.         repository.disconnect();  
  67.     }  
  68.   
  69. }  
 

你可能感兴趣的:(Kettle)