首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Liquibase与Maven

Liquibase与Maven
EN

Stack Overflow用户
提问于 2013-01-22 15:19:31
回答 1查看 17.9K关注 0票数 2

我想为Java项目启动Liquibase,这样我就可以在生产服务器上轻松地进行DB更新。

我很难理解我需要什么才能开始。我在许多例子中看到,您需要下载液化基核,提取它并将.jar放到您的路径上。我觉得这对Maven来说不需要。

要在pom.xml中包含依赖项(核心和液化基maven-plugin)应该足够/应该是相同的?

代码语言:javascript
复制
    <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的经验。

EN

回答 1

Stack Overflow用户

发布于 2018-02-19 18:08:42

在我看来,你有点搞不懂在你的项目中增加液化资产的方法。我们不应该将液化基理解为一个简单的依赖项,它是一个maven插件

我认为,如果您看到我的一些配置文件以更好地理解我指的是什么,那就很明显了:

pom.xml:

代码语言:javascript
复制
<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:

代码语言:javascript
复制
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文件。每个液化基上下文都需要一个像这样的适当属性文件来指定模式和changelog。它提供了与不同环境(dsv、本地、测试、pro、.)一起工作的能力。并仅在指定的环境/上下文中应用这些更改。

项目文件夹:

对于我们的团队来说,这种结构是非常干净的,因为我们所有的changelog都是按照版本和函数、过程和视图组织的,与根数据库的更改是分开的,但是这里最重要的是,每个更改都有与问题/任务代码相关联的问题/任务代码,而且我们可以很容易地跟踪所有内容。

mvn:

要执行液化库插件,您应该执行mvn命令:

代码语言:javascript
复制
mvn liquibase:update

您还可以自动更新数据库,因为清算库的插件param:

代码语言:javascript
复制
<execution>
   <phase>process-resources</phase>
   <goals>
       <goal>update</goal>
   </goals>
</execution>

我们在几个项目中使用清算库,而不深入使用它的利弊,将数据库版本控制、历史记录、不同项目的共同逻辑和维护作为我们开发团队的强制性要求。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14461891

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档