Scala Error: java.sql.SQLException: No suitable driver found for jdbc:calcite:
Scala Error: java.sql.SQLException: No suitable driver found for jdbc:calcite:
我使用 maven-assembly-plugin
创建了一个 Scala 应用程序的 jar。现在,当我使用 java -jar path\to\jar\myapp.jar
执行 jar 时,它会抛出以下错误:
Exception in thread "main" Exception in thread "Timer-0" java.lang.RuntimeException: java.sql.SQLException: No suitable driver found for jdbc:calcite:
at org.apache.calcite.tools.Frameworks.withPrepare(Frameworks.java:159)
at org.apache.calcite.tools.Frameworks.withPlanner(Frameworks.java:114)
Caused by: java.sql.SQLException: No suitable driver found for jdbc:calcite:
at java.sql.DriverManager.getConnection(Unknown Source)
at java.sql.DriverManager.getConnection(Unknown Source)
at org.apache.calcite.tools.Frameworks.withPrepare(Frameworks.java:153)
... 17 more
java.lang.RuntimeException: java.sql.SQLException: No suitable driver found for jdbc:calcite:
at org.apache.calcite.tools.Frameworks.withPrepare(Frameworks.java:159)
at org.apache.calcite.tools.Frameworks.withPlanner(Frameworks.java:114)
at java.util.TimerThread.mainLoop(Unknown Source)
at java.util.TimerThread.run(Unknown Source)
Caused by: java.sql.SQLException: No suitable driver found for jdbc:calcite:
at java.sql.DriverManager.getConnection(Unknown Source)
at java.sql.DriverManager.getConnection(Unknown Source)
at org.apache.calcite.tools.Frameworks.withPrepare(Frameworks.java:153)
... 8 more
当我通过 IDE (IntelliJ) 运行 应用程序时,它工作正常。
谁能告诉我为什么会这样?
EDIT1:我打开了 jar 文件,看到 calcite-core
jar 存在于 org/apache/calcite
jar 中。
EDIT2:我尝试更改 calcite-core
的版本。我之前使用的是 1.15.0
,现在我使用的是 1.18.0
,但错误仍然存在。
似乎 Apache Flink 中存在错误 - https://issues.apache.org/jira/browse/FLINK-4581
虽然我还没有找到解决 calcite-core
驱动程序问题的方法,但我设法找到了另一种执行 jar 的方法。
我在 pom.xml
中添加了以下两个插件。 maven-dependency-plugin
将所有相关的依赖 jar 复制到 lib
文件夹中,maven-jar-plugin
生成单个可执行 jar 文件。
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-dependency-plugin</artifactId>
<configuration>
<outputDirectory>${project.build.directory}/lib</outputDirectory>
<excludeTransitive>false</excludeTransitive>
<stripVersion>false</stripVersion>
</configuration>
<executions>
<execution>
<id>copy-dependencies</id>
<phase>package</phase>
<goals>
<goal>copy-dependencies</goal>
</goals>
</execution>
</executions>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
<version>2.4</version>
<configuration>
<archive>
<manifest>
<addClasspath>true</addClasspath>
<classpathPrefix>lib/</classpathPrefix>
<mainClass>com.example.MainClass</mainClass>
</manifest>
</archive>
</configuration>
</plugin>
注意:添加 <mainClass>com.example.MainClass</mainClass>
将使 manifest.mf
知道主要的 class 是什么。
我使用 maven-assembly-plugin
创建了一个 Scala 应用程序的 jar。现在,当我使用 java -jar path\to\jar\myapp.jar
执行 jar 时,它会抛出以下错误:
Exception in thread "main" Exception in thread "Timer-0" java.lang.RuntimeException: java.sql.SQLException: No suitable driver found for jdbc:calcite:
at org.apache.calcite.tools.Frameworks.withPrepare(Frameworks.java:159)
at org.apache.calcite.tools.Frameworks.withPlanner(Frameworks.java:114)
Caused by: java.sql.SQLException: No suitable driver found for jdbc:calcite:
at java.sql.DriverManager.getConnection(Unknown Source)
at java.sql.DriverManager.getConnection(Unknown Source)
at org.apache.calcite.tools.Frameworks.withPrepare(Frameworks.java:153)
... 17 more
java.lang.RuntimeException: java.sql.SQLException: No suitable driver found for jdbc:calcite:
at org.apache.calcite.tools.Frameworks.withPrepare(Frameworks.java:159)
at org.apache.calcite.tools.Frameworks.withPlanner(Frameworks.java:114)
at java.util.TimerThread.mainLoop(Unknown Source)
at java.util.TimerThread.run(Unknown Source)
Caused by: java.sql.SQLException: No suitable driver found for jdbc:calcite:
at java.sql.DriverManager.getConnection(Unknown Source)
at java.sql.DriverManager.getConnection(Unknown Source)
at org.apache.calcite.tools.Frameworks.withPrepare(Frameworks.java:153)
... 8 more
当我通过 IDE (IntelliJ) 运行 应用程序时,它工作正常。
谁能告诉我为什么会这样?
EDIT1:我打开了 jar 文件,看到 calcite-core
jar 存在于 org/apache/calcite
jar 中。
EDIT2:我尝试更改 calcite-core
的版本。我之前使用的是 1.15.0
,现在我使用的是 1.18.0
,但错误仍然存在。
似乎 Apache Flink 中存在错误 - https://issues.apache.org/jira/browse/FLINK-4581
虽然我还没有找到解决 calcite-core
驱动程序问题的方法,但我设法找到了另一种执行 jar 的方法。
我在 pom.xml
中添加了以下两个插件。 maven-dependency-plugin
将所有相关的依赖 jar 复制到 lib
文件夹中,maven-jar-plugin
生成单个可执行 jar 文件。
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-dependency-plugin</artifactId>
<configuration>
<outputDirectory>${project.build.directory}/lib</outputDirectory>
<excludeTransitive>false</excludeTransitive>
<stripVersion>false</stripVersion>
</configuration>
<executions>
<execution>
<id>copy-dependencies</id>
<phase>package</phase>
<goals>
<goal>copy-dependencies</goal>
</goals>
</execution>
</executions>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
<version>2.4</version>
<configuration>
<archive>
<manifest>
<addClasspath>true</addClasspath>
<classpathPrefix>lib/</classpathPrefix>
<mainClass>com.example.MainClass</mainClass>
</manifest>
</archive>
</configuration>
</plugin>
注意:添加 <mainClass>com.example.MainClass</mainClass>
将使 manifest.mf
知道主要的 class 是什么。