首页 > 解决方案 > 在 Talend 中导入外部 jar

问题描述

谁能帮我解决这个问题。我已经成功安装了 Talend studio (Talend Data Fabric 7.3.1)。但是当我尝试使用 tDBInput 组件连接到 Azure SQL 数据库时,它向我显示了一个错误,即缺少 jar "mssql-jdbc.jar"。由于下载按钮被禁用。

请参阅下面的快照,显示下载按钮已禁用

显示组件中的下载按钮已禁用的屏幕截图

我手动下载了 jar“mssql-jdbc-8.4.0.jre11”并将其指向组件。当我执行我的 Talend 作业时,它显示以下错误

Exception in thread "main" java.lang.UnsupportedClassVersionError: com/microsoft/sqlserver/jdbc/SQLServerDriver has been compiled by a more recent version of the Java Runtime (class file version 59.0), this version of the Java Runtime only recognizes class file versions up to 55.0
      at java.base/java.lang.ClassLoader.defineClass1(Native Method)
      at java.base/java.lang.ClassLoader.defineClass(ClassLoader.java:1017)
      at java.base/java.security.SecureClassLoader.defineClass(SecureClassLoader.java:174)
      at java.base/jdk.internal.loader.BuiltinClassLoader.defineClass(BuiltinClassLoader.java:800)
      at java.base/jdk.internal.loader.BuiltinClassLoader.findClassOnClassPathOrNull(BuiltinClassLoader.java:698)
      at java.base/jdk.internal.loader.BuiltinClassLoader.loadClassOrNull(BuiltinClassLoader.java:621)
      at java.base/jdk.internal.loader.BuiltinClassLoader.loadClass(BuiltinClassLoader.java:579)
      at java.base/jdk.internal.loader.ClassLoaders$AppClassLoader.loadClass(ClassLoaders.java:178)
      at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:522)
      at java.base/java.lang.Class.forName0(Native Method)
      at java.base/java.lang.Class.forName(Class.java:315)
      at psc_co_biopharm.test_job_0_1.Test_job.tDBInput_2Process(Test_job.java:727)
      at psc_co_biopharm.test_job_0_1.Test_job.runJobInTOS(Test_job.java:1458)
      at psc_co_biopharm.test_job_0_1.Test_job.main(Test_job.java:1240)

所以,我尝试了解决方法。使用 tlibraryload 组件导入 jar “mssql-jdbc-8.2.1jre11”。它有效,我能够查询 Azure SQL 数据库。

显示 tlibraryload 工作正常的屏幕截图

但是使用 tlibraryload 不是最好的做法,有人可以告诉我如何将这个版本的 jar "mssql-jdbc-8.2.1jre11" 直接指向组件。

我尝试通过 windows->show_view->Modules 加载这个 jre。但它显示“这个模块已经安装了 Maven URI”

屏幕截图显示通过 windows->showview->modules 导入 jre 不起作用

请帮助我并建议如何将这个版本的 jar "mssql-jdbc-8.2.1jre11" 直接指向组件。

标签: javatalend

解决方案


我发布了这个问题的答案,所以这将对将来的某人有所帮助。我犯的错误是,首先我应该下载“mssql-jdbc-8.2.1jre11”jar并将其指向组件,而不是下载“mssql-jdbc-9.1jre”并指向零件。这是一个可怕的错误。

确保您正在下载与您的 jdk 兼容的正确版本的 jar。对我来说,jdk 版本是 11,所以我应该首先下载“mssql-jdbc-8.2.1jre11”jar。

由于我已经下载了不同版本的 jar 并首先指向该组件,因此它不接受我现在指向的正确版本的 jar“mssql-jdbc-8.2.1jre11”。我们应该从以下文件夹中删除旧的 jar,并且我们应该尝试导入正确版本的 jar。它会起作用的。它对我来说效果很好。

我们应该从系统中的以下文件夹中删除旧 jar

Windows(c)->Talend_Studio->配置->.m2->存储库->org->Talend->库

在这个库文件夹下,对于我来说,我应该找到文件夹 MySQL 目录并将其删除。

然后我尝试通过 windows->show_view->Modules 导入 jar 它工作。:-)

希望这对某人有用。


推荐阅读