高大卫 2022-03-09 12:38 采纳率: 100%
浏览 194
已结题

如何使用Java调用Kettle脚本,出现Caused by: org.pentaho.di.core.exception.KettleDatabaseException?

1.创建kettle脚本,并且可以成功运行转换,数据库连接也没问题!

img

2.Java代码

String fileName = "C:\\Users\\GaoHao\\Desktop\\Text\\ct_test.ktr";
        System.out.println("-----------");
        KettleEnvironment.init();
        TransMeta transMeta = new TransMeta(fileName);
        Trans trans = new Trans(transMeta);
        trans.execute(null);
        trans.waitUntilFinished();

3.报错信息

2022/03/09 12:31:39 - 表输出.0 - ERROR (version 9.0.0.0-423, build 9.0.0.0-423 from 2020-01-31 04.53.04 by buildguy) : An error occurred intialising this step: 
2022/03/09 12:31:39 - 表输出.0 - Error occurred while trying to connect to the database
2022/03/09 12:31:39 - 表输出.0 - 
2022/03/09 12:31:39 - 表输出.0 - Driver class 'org.gjt.mm.mysql.Driver' could not be found, make sure the 'MySQL' driver (jar file) is installed.
2022/03/09 12:31:39 - 表输出.0 - org.gjt.mm.mysql.Driver
2022/03/09 12:31:39 - 表输出.0 - ERROR (version 9.0.0.0-423, build 9.0.0.0-423 from 2020-01-31 04.53.04 by buildguy) : 错误初始化步骤[表输出]
2022/03/09 12:31:39 - ct_test - ERROR (version 9.0.0.0-423, build 9.0.0.0-423 from 2020-01-31 04.53.04 by buildguy) : 步骤 [表输出.0] 初始化失败!
2022/03/09 12:31:39 - 表输出.0 - ERROR (version 9.0.0.0-423, build 9.0.0.0-423 from 2020-01-31 04.53.04 by buildguy) : Unexpected error rolling back the database connection.
2022/03/09 12:31:39 - 表输出.0 - ERROR (version 9.0.0.0-423, build 9.0.0.0-423 from 2020-01-31 04.53.04 by buildguy) : org.pentaho.di.core.exception.KettleDatabaseException: 
2022/03/09 12:31:39 - 表输出.0 - Unable to get database metadata from this database connection
2022/03/09 12:31:39 - 表输出.0 - 
2022/03/09 12:31:39 - 表输出.0 - Error connecting to database [ct_test]
2022/03/09 12:31:39 - 表输出.0 - 
2022/03/09 12:31:39 - 表输出.0 - 
2022/03/09 12:31:39 - 表输出.0 -     at org.pentaho.di.core.database.Database.getDatabaseMetaData(Database.java:3126)
2022/03/09 12:31:39 - 表输出.0 -     at org.pentaho.di.core.database.Database.rollback(Database.java:906)
2022/03/09 12:31:39 - 表输出.0 -     at org.pentaho.di.core.database.Database.rollback(Database.java:898)
2022/03/09 12:31:39 - 表输出.0 -     at org.pentaho.di.trans.steps.tableoutput.TableOutput.dispose(TableOutput.java:625)
2022/03/09 12:31:39 - 表输出.0 -     at org.pentaho.di.trans.Trans.prepareExecution(Trans.java:1257)
2022/03/09 12:31:39 - 表输出.0 -     at org.pentaho.di.trans.Trans.execute(Trans.java:751)
2022/03/09 12:31:39 - 表输出.0 -     at com.ct.test.kettle.KettleDemo.main(KettleDemo.java:32)
2022/03/09 12:31:39 - 表输出.0 - Caused by: org.pentaho.di.core.exception.KettleDatabaseException: 
2022/03/09 12:31:39 - 表输出.0 - Error connecting to database [ct_test]
2022/03/09 12:31:39 - 表输出.0 - 
2022/03/09 12:31:39 - 表输出.0 -     at org.pentaho.di.core.database.Database.getDatabaseMetaData(Database.java:3120)
2022/03/09 12:31:39 - 表输出.0 -     ... 6 more
Exception in thread "main" org.pentaho.di.core.exception.KettleException: 
无法初始化至少一个步骤.  执行无法开始!

4.解决办法
需要单独添加mysql-connector-java-5.1.47-bin.jar这个依赖。
jar包下载地址:http://www.java2s.com/Code/Jar/m/Downloadmysqlconnectorjava5123binjar.htm

img

运行成功!

img

  • 写回答

2条回答 默认 最新

  • 关注

    你这是解决了记录过程?

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
  • 有问必答小助手 2022-03-09 14:55
    关注
    您好,我是有问必答小助手,您的问题已经有小伙伴帮您解答,感谢您对有问必答的支持与关注!
    PS:问答VIP年卡 【限时加赠:IT技术图书免费领】,了解详情>>> https://vip.csdn.net/askvip?utm_source=1146287632
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 3月17日
  • 已采纳回答 3月9日
  • 创建了问题 3月9日

悬赏问题

  • ¥15 我不明白为什么c#微软的官方api浏览器为什么不支持函数说明的检索,有支持检索函数说明的工具吗?
  • ¥15 ORBSLAM2框架跑ICL-NUIM数据集
  • ¥15 在我想检测ros是否成功安装时输入roscore出现以下
  • ¥30 老板让我做一个公司的投屏,实时显示日期,时间,安全生产的持续天数,完全没头绪啊
  • ¥15 Google Chrome 所有页面崩溃,三种解决方案都没有解决,我崩溃了
  • ¥20 使用uni-app发起网络请求,获取重定向302返回的cookie
  • ¥20 手机外部浏览器拉起微信小程序支付 (相关搜索:微信小程序)
  • ¥20 怎样通过一个网址找到其他同样模版的网址
  • ¥30 XIAO esp32c3 读取FDC2214的数据
  • ¥15 在工控机(Ubuntu系统)上外接USB蓝牙硬件进行蓝牙通信