Flyway - Version control for your database
Flyway 是什么?
Flyway是个数据库版本管理工具。在开发过程中,数据库难免发生变更,例如数据变更,表结构变更、新建表或者视图等等。
在项目进行时无法保证一旦开发环境中的数据库内容变化候会去测试环境去更新数据库。
即使开发环境有变化不同时去测试环境执行,那么也需要保留所有的SQL脚本,待开发完成再去测试环境一一执行。
然后去生产环境又要去执行。
如果SQL脚本数量不多还可以接受,一旦数量过多,一个个脚本执行也是相当费时。
Flyway就用作解决此类问题。接下来的内容是在Maven中整合Flyway工具。
如果不想和Maven一起用,Flyway也有命令行、API、Gradle等方式,具体点击这里。
接下来开始正片!
开始前准备
此文使用的Flyway 5.2.4版本,Java环境和Maven的安装不再赘述,对应Java和Maven版本如下:
环境:
Java 8, 9, 10 or 11
Maven 3.x
编辑器:
IDEA
数据库:
MySQL
环境安装好之后需要新建一个Maven项目。
这里使用数据库是MySQL,如果不是MySQL也可以按照此文做,
不同的就是连接数据库的URL和数据库驱动,当然还有一些特定的配置也会不一样,但是没什么影响。
一切准备就绪之后开始Flyway的配置,以新建Person表为例。
整合Flyway
第一步
在Maven项目中引入框架或者插件或者其他工具,第一步就是修改pom.xml,引入相关的资源。
这里引入Flyway插件。
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
<!--引入Flyway插件-->
<plugin>
<groupId>org.flywaydb</groupId>
<artifactId>flyway-maven-plugin</artifactId>
<version>5.2.4</version>
<configuration>
<!--数据库连接URL-->
<url>jdbc:mysql://localhost:3306/dbtrial?useUnicode=true&characterEncoding=utf-8&serverTimezone=UTC</url>
<!--数据库连接用户名-->
<user>root</user>
<!--数据库连接密码-->
<password>123</password>
<!--指定数据库-->
<schemas>dbtrial</schemas>
<!--指定如果flyway_schema_history表不存在则新建-->
<baselineOnMigrate>true</baselineOnMigrate>
</configuration>
</plugin>
</plugins>
</build>
注意:因为在pom.xml 字符 “&” 被认作特殊字符,所以这里用 “&”
<schemas>dbtrial</schemas>此配置是为了指定数据库中脚本在那个数据库下面执行。
flyway_schema_history 表使用来记录执行日志的,下图是表中记录的内容,
第一条是创建日志表,第二条是执行项目里面的SQL脚本(当然这是Flyway执行成功后才能看到的,现在提前贴出来方便理解):

因为在创建项目时选择的是web项目,并且选了使用MySQL数据库所以已经有了MySQL的数据库驱动。
如果没有,则需要在pom.xml中添加依赖
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
第二步
pom.xml修改完成之后,接下来需要准备要执行的SQL脚本。
但是在新建SQL脚本之前需要先在项目中创建一个文件夹存放脚本文件。
路径:\src\main\resources\db\migration
注意:这里在创建文件夹时,Flyway默认的就是上面的路径。(虽然配置也可以修改,但是新学不建议搞得太复杂)
然后在创建好的路径下面新建SQL脚本文件
路径:\src\main\resources\db\migration\V1.1__CreatePersonTable.sql注意:文件的命名要使用推荐的格式如用V1.0、V1.1、V1.x这种格式。好处在于,
Flyway对脚本文件的命名非常敏感,格式不对可能会报错,再者就是利于查看,看文件名就能知道版本先后。
版本号后面一定要跟两个下划线。否则一直会报错文件名格式不正确。
目录结构:

SQL脚本:
create table PERSON (
ID int not null,
NAME varchar(100) not null
);
第三步
万事俱备只欠东风,最后我们需要做的就是让Flyway执行起来,自动更新数据库。
打开terminal,然后输入命令:
执行之后的输出信息:

然后查看数据库:

总结
入门级文章,如有错误或者疑问欢迎指出。
Flyway的功能很强大,支持市面上非常多的数据库。
能同时执行不同数据库的脚本,支持事务等等。
深入用法可以访问官网。
Flyway - Version control for your database的更多相关文章
- which type of VS files should be committed into a version control system
which type of VS files should be committed into a version control system? aps, no: last resource edi ...
- xcode svn commit is not under version control (1) & git commit
使用Xcode提交一个第三方库时,由于包含资源文件,总是提交不了,提示报错:XXX commit is not under version control (1) 网上查了下,得知 xcode对于sv ...
- svn: warning: 'xxxxxx' is already under version control
[root@NGINX-APACHE-SVN pm]# svn status ? plugins ? files ? images ? data ? resources [root@NGINX-APA ...
- svn is already under version control问题解决
svn ci 时出现 xx is already under version control,然后无法提交,出现这个问题的原因是你所提交的文件或目录是其他SVN的东西,即下面有.svn的目录,需要先把 ...
- Git&Version Control
Git Git(读音为/gɪt/.)是一个开源的分布式版本控制系统,可以有效.高速地处理从很小到非常大的项目版本管理. [1] Git 是 Linus Torvalds 为了帮助管理 Linux 内 ...
- Version Control/Git,SVN
一.Version Control 1.什么是Version Control 版本控制(Version Control)是指对软件开发过程中各种程序代码.配置文件及说明文档等文件变更的管理,是软件配置 ...
- xcode svn commit is not under version control 和 git常用指令
使用Xcode提交一个第三方库时,由于包含资源文件,总是提交不了,提示报错:XXX commit is not under version control (1) 网上查了下,得知 xcode对于sv ...
- version control的简单认知
version control 版本控制是一种记录文件或文件集随时间变化的系统,以便您以后可以调用特定版本.对于本书中的示例,您将使用软件源代码作为受版本控制的文件,但实际上您可以使用计算机上的几乎任 ...
- 【转】svn:is not under version control and is not part of the commit, yet its child解决办法
来自:http://blog.csdn.net/lufeng20/article/details/7641093 在把写好的代码提交到svn上面时,遇到了一个错误如下: svn: Commit fai ...
随机推荐
- shell 跟踪命令
添加跟踪 set -x 去除跟踪 set +x
- 17-vim-查找字符或单词-02-查找并替换
在vi中查找和替换命令需要在末行模式下执行. 命令 功能 :%s///g 末行模式下,查找并替换字符.例:%s /hello/world/g 1.全局替换 一次性替换文件中的所有文件的旧文本. 命令格 ...
- CF1220F
CF1220F 把整棵树分成1的左边和1的右边两部分 最优情况两边子树深度的差一定可以是一 如果还可以是2,也可以通过把多的那一边的点往另一边移使他变成1 如果往一个端点加点,一定不会使这一边变优,也 ...
- 挂载时出现mount: RPC: Unable to receive; errno = Connection refused错误的解决方法
当我们在做NFS开发板下挂载时,经常会出现mount: RPC: Unable to receive; errno = Connection refused的错误,连接被拒绝了,到底是什么原因呢? 这 ...
- AJAX 向后台发送带 List 集合的对象(转)
var school = {};school.name = '清华大学';school.address = "北京";//此处使用的是 easyui 插件来获取数据var rows ...
- openses机制
openses 大体结构解读 页面html与相关php文件的定位 点击界面,查看出现的url 例如: http://localhost/opensns/index.php?s=/people/inde ...
- git安装和使用方法url
1.如何在ubuntu下使用Github? https://blog.csdn.net/tina_ttl/article/details/51326684 https://segmentfault.c ...
- docker安装cboard
参考链接: https://hub.docker.com/r/chenlmdocker/docker-cboard/dockerfile https://www.cnblogs.com/zimo-ji ...
- CF232E Quick Tortoise , Fzoj 3118
这一题由于数据较多,我们考虑离线处理. 分治.对于两个点s,t,如果起点在mid这条横线上方,终点在下方,那么它必定会穿过mid这条线.所以只要s可以到mid上一点x,x可以到t,st就是安全的. 用 ...
- 使用pangolin库画出轨迹
https://github.com/stevenlovegrove/Pangolin cmake_minimum_required(VERSION 2.8) project(chapter3) ) ...