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&amp;characterEncoding=utf-8&amp;serverTimezone=UTC</url>
<!--数据库连接用户名-->
<user>root</user>
<!--数据库连接密码-->
<password>123</password>
<!--指定数据库-->
<schemas>dbtrial</schemas>
<!--指定如果flyway_schema_history表不存在则新建-->
<baselineOnMigrate>true</baselineOnMigrate>
</configuration>
</plugin>
</plugins>
</build>

注意:因为在pom.xml 字符 “&” 被认作特殊字符,所以这里用 “&amp;”

   <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的更多相关文章

  1. 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 ...

  2. xcode svn commit is not under version control (1) & git commit

    使用Xcode提交一个第三方库时,由于包含资源文件,总是提交不了,提示报错:XXX commit is not under version control (1) 网上查了下,得知 xcode对于sv ...

  3. svn: warning: 'xxxxxx' is already under version control

    [root@NGINX-APACHE-SVN pm]# svn status ? plugins ? files ? images ? data ? resources [root@NGINX-APA ...

  4. svn is already under version control问题解决

    svn ci 时出现 xx is already under version control,然后无法提交,出现这个问题的原因是你所提交的文件或目录是其他SVN的东西,即下面有.svn的目录,需要先把 ...

  5. Git&Version Control

    Git Git(读音为/gɪt/.)是一个开源的分布式版本控制系统,可以有效.高速地处理从很小到非常大的项目版本管理. [1]  Git 是 Linus Torvalds 为了帮助管理 Linux 内 ...

  6. Version Control/Git,SVN

    一.Version Control 1.什么是Version Control 版本控制(Version Control)是指对软件开发过程中各种程序代码.配置文件及说明文档等文件变更的管理,是软件配置 ...

  7. xcode svn commit is not under version control 和 git常用指令

    使用Xcode提交一个第三方库时,由于包含资源文件,总是提交不了,提示报错:XXX commit is not under version control (1) 网上查了下,得知 xcode对于sv ...

  8. version control的简单认知

    version control 版本控制是一种记录文件或文件集随时间变化的系统,以便您以后可以调用特定版本.对于本书中的示例,您将使用软件源代码作为受版本控制的文件,但实际上您可以使用计算机上的几乎任 ...

  9. 【转】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 ...

随机推荐

  1. MySQL数据库安装与启动(Linux)

    1.用yum安装 用root权限打开命令行界面,执行以下yum指令: yum安装MySQL yum install mysql mysql-server mysql-devel -y 在最终提示Com ...

  2. C# winform 动态操作webService

    1.动态操作webService类 public static class WebServiceHelper { #region InvokeWebService //动态调用web服务 public ...

  3. springboot整合netty,多种启动netty的方式,展现bean得多种启动方法

    首先讲解下,spring中初始化加载问题: 很多时候,我们自己写的线程池,还有bean对象,还有其他的服务类,都可以通过,相关注解进行交给spring去管理,那么我们如何让nettyserver初始化 ...

  4. 使用allure2生成精美报告

    安装:brew install allure pip install allure-pytest 在测试执行期间收集结果 pytest -s –q --alluredir=./result/ 测试完成 ...

  5. python发送微信及企业微信消息

    1.发送微信消息 直接使用第三方库 itchat,其文档中有详细使用方式:https://itchat.readthedocs.io/zh/latest/ 如下实例为 发送群聊信息 # -*- cod ...

  6. KiCAD原理图导出PDF方法

    KiCAD原理图导出为PDF 1.文件->绘制 2.按照下图选择保存目录和输出格式后,选择绘制当前页或者所有页

  7. MySQL源码编译与初始化

    MySQL源码编译与初始化 链接:https://pan.baidu.com/s/1ANGg3Kd_28BzQrA5ya17fQ 提取码:ekpy 复制这段内容后打开百度网盘手机App,操作更方便哦 ...

  8. 运行连接Oracle数据库时,Idea报错: Error : java 不支持发行版本5

    按照上面的截图步骤,一步步往下走,再运行程序时就不会报错了. 原文链接:https://blog.csdn.net/qq_22076345/article/details/82392236 感谢原文作 ...

  9. hibernate3.6异常

    WARN DTDEntityResolver:73 - recognized obsolete hibernate namespace http://hibernate.sourceforge.net ...

  10. git - Mac生成SSH key

    步骤1.检查是否已经存在SSH Key 打开电脑终端,输入以下命令: ls -al ~/.ssh 会出现两种情况 步骤2. 生成/设置SSH Key 继续上一步可能出现的情况 (1)情况一: 终端出现 ...