Не удается найти драйвер базы данных: org.в PostgreSQL.Водитель
Im пытается немного изменить проект, обновив его с помощью Liquibase. Его проект Java EE. Поэтому я использую плагин liquibase-maven.
до сих пор у меня в моем пом.XML-код:
<plugin>
<groupId>org.liquibase</groupId>
<artifactId>liquibase-maven-plugin</artifactId>
<version>2.0.5</version>
<configuration>
<propertyFileWillOverride>true</propertyFileWillOverride>
<propertyFile>src/main/resources/liquibase.properties</propertyFile>
<changeLogFile>src/main/resources/changelogs/changelog.xml</changeLogFile>
</configuration>
<executions>
<execution>
<!-- Another Error: plugin execution not covered by lifecycle configuration..-->
<!-- <phase>process-resources</phase> <goals> <goal>update</goal> </goals> -->
</execution>
</executions>
</plugin>
который уже включает в себя драйвер:
<dependency>
<groupId>postgresql</groupId>
<artifactId>postgresql</artifactId>
<version>9.1-901-1.jdbc4</version>
</dependency>
В при.свойства файла и URL-адрес, имя пользователя, пароль, changeLogFile-путь и водитель:
#liquibase.properties
driver: org.postgresql.Driver
но у него нет пути к классам для драйвера. Нужен ли мне classpath как ну?
изменений.XML имеет простой набор изменений, который создает таблицу, просто чтобы проверить, при начала.
но я не зашел так далеко, потому что когда я запускаю проект с
mvn liquibase:update
я получаю эту ошибку:
[ошибка] не удалось выполнить цель орг.liquibase:liquibase-maven-plugin: 2.0.5: обновление (по умолчанию-cli) в проекте Проект: ошибка настройки или запуска Liquibase: java.ленг.RuntimeException: не удается найти драйвер базы данных: орг.в PostgreSQL.Водитель!--6-->
Я не вижу смысла.. Драйвер уже использовался ранее в проекте. Так почему liquibase не может найти его?
редактировать
когда я редактирую свою конфигурацию в pom.xml, добавив тег драйвера, он работает:
<configuration>
<propertyFileWillOverride>true</propertyFileWillOverride>
<propertyFile>src/main/resources/liquibase.properties</propertyFile>
<changeLogFile>src/main/resources/changelogs/changelog.xml</changeLogFile>
<driver>org.postgresql.Driver</driver>
</configuration>
до этого мой водитель был указан в при.свойства, которые также должны работать.
может быть, кто-то может сказать мне, как при.файл свойств должно выглядеть так, если id хочет сохранить драйвер в файле свойств.
1 ответов
вы добавили драйвер postgresql в качестве зависимости от вашего webapp. Но когда Плагины maven работают, у них есть свой собственный путь к классам, который отличается от вашего webapp. Поэтому вам нужно включить зависимость от драйвера JDBC для самого плагина (то же самое относится к другим плагинам, например, jetty-maven-plugin):
<plugin>
<groupId>org.liquibase</groupId>
<artifactId>liquibase-maven-plugin</artifactId>
<version>2.0.5</version>
<configuration>
<propertyFileWillOverride>true</propertyFileWillOverride>
<propertyFile>src/main/resources/liquibase.properties</propertyFile>
<changeLogFile>src/main/resources/changelogs/changelog.xml</changeLogFile>
</configuration>
<executions>
<execution>
<!-- Another Error: plugin execution not covered by lifecycle configuration..-->
<!-- <phase>process-resources</phase> <goals> <goal>update</goal> </goals> -->
</execution>
</executions>
<dependencies>
<dependency>
<groupId>postgresql</groupId>
<artifactId>postgresql</artifactId>
<version>9.1-901-1.jdbc4</version>
</dependency>
</dependencies>
</plugin>
Edit:
проблема была решена путем заменыdriver: org.postgresql.Driver
С driver=org.postgresql.Driver
в liquibase.файл свойств.