这几天小白得到了一个任务,需要写一个简单的程序,执行本地的ktr文件,ktr文件中会更新数据库数据,且数据库连接信息需从执行这段程序的机器的资源库中获取,再次记录下这段程序。
目录
工程
首先,新建一个springboot工程,方便将依赖包打包进jar文件。
代码
然后main函数代码如下代码所示,其中有的变量我重新命名了下。
package com.xxxx.xxxxa;
import xxxxxx;
@SpringBootApplication
public class xxxxApplication {
public static void main(String[] args) throws Exception{
KettleEnvironment.init();//初始化环境
RepositoriesMeta repositoriesMeta = new RepositoriesMeta();
if (repositoriesMeta.readData()) {
KettleDatabaseRepositoryMeta xxxRepo = (KettleDatabaseRepositoryMeta) repositoriesMeta.searchRepository("xxx-repo");
String databaseMetaName = (null == xxxRepo ? "xxx-repo-connection" : xxxRepo.getConnection().getName());
DatabaseMeta xxxRepoConn = repositoriesMeta.searchDatabase(databaseMetaName);
System.out.println("连接名称:" + xxxRepoConn);
if (null == xxxRepoConn) {
throw new Exception("xxx资源库配置有误,请重新配置后再次运行!");
} else {
// 数据库信息确认
Scanner sc = new Scanner(System.in);
System.out.println("请确认需要执行的数据库信息,如正确,输入Y后回车执行;如错误,请检查xxx资源库配置。");
System.out.println("数据库类型:" + xxxRepoConn.getPluginId()); //数据库类型
System.out.println("连接地址:" + xxxRepoConn.getHostname()); //连接地址
System.out.println("数据库名称" + xxxRepoConn.getDatabaseName()); //数据库名称
System.out.println("端口" + xxxRepoConn.getDatabasePortNumberString()); //端口
System.out.println("用户" + xxxRepoConn.getUsername()); //用户
String indexStr = sc.nextLine();
if(!"Y".equalsIgnoreCase(indexStr)){
throw new Exception("取消执行!");
}
String errorFile = null;
String dir = new ApplicationHome().toString() + "/ktrs/" ;
System.out.println(new ApplicationHome());
System.out.println(dir);
File file = new File(dir);
File[] tempList = file.listFiles();

本文档介绍了一个使用SpringBoot应用程序来执行Kettle(Pentaho Data Integration,KDI)的.ktr文件,这些文件用于更新数据库。程序从本地资源库获取数据库连接信息,并在用户确认后执行转换。程序会检查Oracle、SQL Server和达梦数据库的驱动,并在执行完成后清理成功运行的.ktr文件。
最低0.47元/天 解锁文章
5692

被折叠的 条评论
为什么被折叠?



