Liquibase与Maven

时间:2013-01-22 15:19:32

标签: maven liquibase

我想为Java EE项目启动Liquibase,因此我可以在生产服务器上轻松进行数据库更新。

我在理解开始时需要什么时遇到问题。我在很多例子中读到你需要下载liquibase-core,解压缩并将.jar放到你的PATH中。我认为Maven不需要这个。

在pom.xml中包含依赖项(core和liquibase-maven-plugin)应该足够/应该相同吗?

    <dependency>
        <groupId>org.liquibase</groupId>
        <artifactId>liquibase-maven-plugin</artifactId>
        <version>2.0.5</version>
        <type>maven-plugin</type>
    </dependency>
    <dependency>
        <groupId>org.liquibase</groupId>
        <artifactId>liquibase-core</artifactId>
        <version>2.0.5</version>
    </dependency>

这可能是一个愚蠢的问题,但我几乎没有使用过Maven而没有使用Liquibase。

1 个答案:

答案 0 :(得分:1)

在我看来,你对将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上下文都需要一个适当的属性文件来指定schema和changelog。这提供了实时处理不同环境( dsv,local,test,pro,... )的能力,并仅在指定的环境/上下文中应用更改。

项目文件夹:

enter image description here

我们团队的结构非常干净,因为我们所有的变更日志都是根据版本和功能,程序和视图与根数据库更改分开组织的,但最重要的是每个变更都有关联的问题/任务代码,我们可以跟踪一切都那么容易。

MVN:

要执行liquibase插件,您应该执行该mvn命令:

mvn liquibase:update

由于liquibase pom的插件参数,你也可以自动更新数据库:

<execution>
   <phase>process-resources</phase>
   <goals>
       <goal>update</goal>
   </goals>
</execution>

我们在几个项目中使用liquibase而没有深入使用它的专业人员,将数据库版本控制,历史记录,差异项目和维护的通用逻辑作为我们开发团队的强制要求。