一般来说,软件发布应该包含文档、代码和DB脚本等,在发布上线时,一般都需要先执行DB脚本,再启动软件,犹豫一些疏忽之类,经常容易出现数据库未升级导致软件发布失败的场景,因此一些组件提供了启动自动执行DB的操作,例如hibernate提供了auto_ddl的属性,能够根据实体类自动进行DDL操作,但是对于数据的升级,例如需要插入初始数据或者修改数据库数据时,一般只能靠发布者手动执行。 flywaydb就是一个解决数据库版本迁移的工具,不仅执行DDL类的数据迁移,同时支持数据类的迁移,为数据库的升级提供了一种很好的解决方案。
flywaydb同时提供了Java API和命令行两种执行方式,其迁移脚本支持SQL或者Java,其对于Java做了很完美的支持,同时提供了与spring整合的功能,因此非常适合整合到Java WEB项目中。flyway默认读取$CLASS_PATH/db/migration目录及其子目录下的SQL或者Java脚本,同时也可以通过locations属性自定义多个目录。
flywaydb对于脚本名称有一定的约束,脚本名称必须以“版本号__描述”的格式组成,版本高可以是整数、浮点数、甚至是日期,例如下面这些都是符合flywaydb的命名方式。
1
001
5.2
5_2
1.2.3.4.5.6.7.8.9
205.68
20130115113556