使用flyway对应用的数据库版本控制
- - Java - 编程语言 - ITeye博客转载自:http://kkuang.net/why-db-migration-tools-flyway/
. 为什么要使用DB migration tools. 我们可以想象,多位开发人员,多个数据库环境. 先前有用过mybatis中的migration,但经常出现莫名其名的异常,并且也不支持多条SQL在1个文件中.

我们可以想象,多位开发人员,多个数据库环境。
偶尔就出现:哎呀!集成环境的数据库忘记更新了。
先前有用过mybatis中的migration,但经常出现莫名其名的异常,并且也不支持多条SQL在1个文件中。
最开始在使用flyway时,没有downgrade。有些觉得奇怪,像mybatis的migration和rails中,都会支持。
后来想想,其实对数据库的downgrade真是要甚用(最好不用),会陷入麻烦,不清楚真实的版本变化。宁可重新写个script downgrade。
这就能在应用程序中,直接进行管理。
我采用的方式,是根据web应用在不同的环境启动时,进行不同环境 db migration.
在往集成发布时,随tomcat执行数据库的版本同步。
具体的使用, flyway官方文档详细简洁,几下就轻松搞定。
这也是非常非常的简化
<bean id="flyway" class="org.flywaydb.core.Flyway" depends-on="dataSource_flyway" lazy-init="false">
<property name="dataSource" ref="dataSource_flyway"/>
</bean>
<bean id="jFlyway" class="net.kkuang.flyway.DbMigration" lazy-init="false" depends-on="flyway">
<property name="flyway" ref="flyway"/>
</bean>
/**
* 执行DbMigration
* 当应用服务启动时会自动执行
*
* User: 闷骚乔巴
* Date: 2014-12-02
*/
public class DbMigration {
private Log log = LogFactory.getLog(DbMigration.class);
private Flyway flyway;
@PostConstruct
public void run() {
log.info("[Start] DbMigration run .. ");
flyway.migrate();
log.info("[End] DbMigration run .. ");
}
public void setFlyway(Flyway flyway) {
this.flyway = flyway;
}
}
SQL Script 命名

flyway执行时,默认读取的目录是 classpath:/db/migration
我们项目中就放在 /resource/db/migration
该文件名由:
* prefix: default: V (大写哦)
* version: 版本号,也可以使用大小版本组合的方式,小版本号用单 _区分
* separator: 分隔符,双下划线 __
* description: 描述(你懂得,必须要有意义)
* suffix: 后缀 default: .sql
再也不用担心,各环境的数据库不一致了。