在我看来,您对将 liquibase 添加到项目中的方法有点困惑。我们不应该将 liquibase 理解为一个简单的依赖项,它是一个 maven 插件。
如果您看到我的一些配置文件以更好地理解我所指的内容,我认为这可能很清楚:
pom.xml:
<build>
<sourceDirectory>src</sourceDirectory>
<pluginManagement>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.6.2</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
<excludes>
<exclude>**/test/*</exclude>
<exclude>**/test/me/*</exclude>
</excludes>
</configuration>
</plugin>
<plugin>
<artifactId>maven-war-plugin</artifactId>
<version>3.1.0</version>
<configuration>
<warSourceDirectory>WebContent</warSourceDirectory>
<failOnMissingWebXml>false</failOnMissingWebXml>
</configuration>
<dependencies>
<dependency>
<groupId>org.codehaus.groovy</groupId>
<artifactId>groovy-eclipse-compiler</artifactId>
<version>2.9.2-01</version>
</dependency>
<dependency>
<groupId>org.codehaus.groovy</groupId>
<artifactId>groovy-eclipse-batch</artifactId>
<version>2.4.3-01</version>
</dependency>
</dependencies>
</plugin>
<plugin>
<groupId>org.liquibase</groupId>
<artifactId>liquibase-maven-plugin</artifactId>
<version>3.5.3</version>
<configuration>
<propertyFile>src/tv/be/persistence/liquibase/code/dsv.properties</propertyFile>
</configuration>
<executions>
<execution>
<phase>process-resources</phase>
<goals>
<goal>update</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</pluginManagement>
</build>
dsv.properties:
driver: com.mysql.jdbc.Driver
classpath: [local_path]/mysql-connector-java/5.1.41/mysql-connector-java-5.1.41.jar
url: jdbc:mysql://[db_server_ip]:3306/schema_db
username: user1
password: masterkey
changeLogFile: src/tv/be/persistence/liquibase/code/master.xml
contexts=local
注意dsv.properties文件。每个 liquibase 上下文都需要一个像这样的适当属性文件来指定架构和更改日志。这提供了实时处理不同环境(dsv、local、test、pro、...)的能力,并仅在指定的环境/上下文中应用更改。
项目文件夹:
这种结构对我们的团队来说非常干净,因为我们将所有变更日志按版本和功能、过程和视图与根数据库更改分开,但这里最重要的是每个更改都有相关的问题/任务代码,我们可以轻松跟踪所有内容.
mvn:
要执行 liquibase 插件,您应该执行该 mvn 命令:
mvn liquibase:update
由于 liquibase pom 的插件参数,您还可以自动更新数据库:
<execution>
<phase>process-resources</phase>
<goals>
<goal>update</goal>
</goals>
</execution>
我们在几个项目中使用 liquibase,并且没有深入了解使用它的优点,数据库版本控制、历史记录、不同项目的通用逻辑和维护是我们开发团队的强制性要求。