我有一个基于Maven的项目,它使用Hibernate和Postgres(无Spring)。
我想使用Liquibase进行数据库迁移。理想情况下,我想要以下工作流程:
-
我创建了初始的"变更集"(mvn-liquibase:generateChangeLog?),它应该初始化数据库。
-
我添加了带有适当注释的实体类。我生成一个"diff"变更集(mvnliqibase:diff?)并将其检查到存储库中。
-
现在,我的团队中的每个人都从存储库中提取并运行一些东西(mvn-update?)来更新他们的数据库副本。
-
我根据需要重复前面的两个步骤。我知道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/
请注意,此命令当前有一些限制。它不导出以下类型的对象:存储过程、函数、包触发器