将maven与liquibase与hibernate连接起来



我有一个基于Maven的项目,它使用Hibernate和Postgres(无Spring)。

我想使用Liquibase进行数据库迁移。理想情况下,我想要以下工作流程:

  1. 我创建了初始的"变更集"(mvn-liquibase:generateChangeLog?),它应该初始化数据库。

  2. 我添加了带有适当注释的实体类。我生成一个"diff"变更集(mvnliqibase:diff?)并将其检查到存储库中。

  3. 现在,我的团队中的每个人都从存储库中提取并运行一些东西(mvn-update?)来更新他们的数据库副本。

  4. 我根据需要重复前面的两个步骤。我知道Liquibase应该支持这种开发工作流程。问题是,有很多移动部件,我很难将连接在一起

例如,如何在Maven中配置Liquibase?在liquibase.properties?如何指定变更集的存储位置?,如何创建初始"变更集"?我知道变更集可以是不同的格式,(XML、JSON等等)有什么优点和缺点,它们可以简单地用SQL吗?

liquibase有一个maven插件,可以通过基于maven的解决方案实现这一点。

http://www.liquibase.org/documentation/maven/generated/update-mojo.html

然后你可以用目标liquibase运行你的maven构建:更新

例如,如果您想连接到mysql数据库(liquibase支持许多不同的数据库)

    <dependencies>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.6</version>
        </dependency>
    </dependencies>


<build>
    <plugins>
        <plugin>
            <groupId>org.liquibase</groupId>
            <artifactId>liquibase-maven-plugin</artifactId>
            <version>3.4.1</version>
            <configuration>
                <promptOnNonLocalDatabase>false</promptOnNonLocalDatabase>
                <changeLogFile>${changelog}</changeLogFile>
                <driver>com.mysql.jdbc.Driver</driver>
                <url>jdbc:mysql://${mysql.host}:${mysql.port}/${mysql.schema}</url>
                <username>${mysql.username}</username>
                <password>${mysql.password}</password>
            </configuration>
        </plugin>
    </plugins>
</build>

我们也可以与hibernate集成,github中有一个项目,请查看他们通过hibernate进行集成的文档。

https://github.com/liquibase/liquibase-hibernate/releases

希望这能回答你的问题

编辑:

liquibase --driver=oracle.jdbc.OracleDriver 
      --classpath=pathtoclasses:jdbcdriver.jar 
      --changeLogFile=com/example/db.changelog.xml 
      --url="jdbc:oracle:thin:@localhost:1521:XE" 
      --username=scott 
      --password=tiger 
      generateChangeLog

这将为现有数据库生成变更日志。

请参阅-http://www.liquibase.org/documentation/generating_changelogs.html

参考——http://bytefilia.com/managing-database-schema-changes-liquibase-existing-schema/

请注意,此命令当前有一些限制。它不导出以下类型的对象:存储过程、函数、包触发器

最新更新