java - 在 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 不是最好的做法,有人可以告诉我如何将这个版本的 jar "mssql-jdbc-8.2.1jre11" 直接指向组件。
我尝试通过 windows->show_view->Modules 加载这个 jre。但它显示“这个模块已经安装了 Maven URI”
请帮助我并建议如何将这个版本的 jar "mssql-jdbc-8.2.1jre11" 直接指向组件。
解决方案
我发布了这个问题的答案,所以这将对将来的某人有所帮助。我犯的错误是,首先我应该下载“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 它工作。:-)
希望这对某人有用。
推荐阅读
- java - 连接到 github/bitbucket 存储库时,自动 Spring boot Docker Image 无法在 docker hub 上构建
- odoo - 我们可以为 Many2many 生成的表制作树视图吗
- flutter - 将地图集转换为地图
- apache - Apache 代理/重定向到 Tomcat 的工作范围是 80 到 8080,但不能从 443 到 8443
- python - 填写时Tkinter检查按钮干扰
- amazon-web-services - API 网关/NLB/ECS 延迟
- python - on_raw_reaction_add(payload) 故障排除
- c# - Net Core 2.2 MVC WebApi 中的 JWT“自我”身份验证
- java - 如何用通用方法替换这些 for 循环
- c++ - C++ 从递归函数中打印出奇怪的字符