首页 > 解决方案 > Scala 错误:java.sql.SQLException:找不到适合 jdbc:calcite 的驱动程序:

问题描述

我使用maven-assembly-plugin. 现在,当我用它执行 jar 时java -jar path\to\jar\myapp.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-corejar 存在于org/apache/calcitejar 中。

EDIT2:我尝试更改calcite-core. 我之前使用1.15.0过,现在我正在使用1.18.0,但错误仍然存​​在。

标签: scalajdbcapache-calcite

解决方案


虽然我还没有找到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知道主类是什么。


推荐阅读