Ошибка Scala: java.sql.SQLException: не найден подходящий драйвер для jdbc: calcite: - PullRequest
0 голосов
/ 18 января 2019

Я создал банку приложения Scala, используя 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: я открыл файл фляги и увидел, что фляга calcite-core присутствует в банке org/apache/calcite.

EDIT2: я пытался изменить версию calcite-core. Я использовал 1.15.0 ранее, а теперь я использую 1.18.0, но ошибка все еще есть.

Ответы [ 2 ]

0 голосов
/ 24 января 2019

Хотя я до сих пор не нашел решения проблемы с драйвером calcite-core, мне удалось найти другой способ выполнить jar.

Я добавил следующие два плагина к своему pom.xml. maven-dependency-plugin копирует все соответствующие банки зависимостей в папку 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 узнает, что такое основной класс.

0 голосов
/ 21 января 2019

Кажется, есть ошибка в Apache Flink - https://issues.apache.org/jira/browse/FLINK-4581

...