1、使用它之前先要了解一些概念:

版本:对数据库的每一次变更可称为一个版本。

迁移:Flyway把数据库结构从一个版本更新到另一个版本叫做迁移。

可用的迁移:Flyway的文件系统识别出来的迁移版本。

已经应用的迁移:Flyway已经对数据库执行过的迁移。

2、flyway最基本的几个命令。

Migrate:应用所有的迁移到最新版本,它会在你的DB中新建个表schema_version来存放每次升级的版本信息。

Clean:clean all objects

Info:打印所有的迁移的信息以及状态。

Validate:迁移之前进行验证。

Baseline:初始化schema_version表,并插入一条原始verion=1。

Repair:它主要做了两件事,移除所有失败的迁移(升级),重置校验和。

3、既支持sql方式升级也支持java方式升级

1、持SQL(还有PL/SQL,T-SQL)文件的方式进行升级(这就是最原始的方式,但是得按照一定的规则规则,例如: V1_0_1__create.sql。

sql脚本的命名规则:

prefix: default:V (大写)

version: 版本号也可以使用大小版本组合的方式,小版本号用单 _区分

separator: 分隔符,双下划线 __

description: 描述(必须要有意义)

suffix: 后缀 default:  .sql

2、当然也支持Java方式,继承 JdbcMigration即可。

4、可以使用命令行客户端command-lineclient来执行命令来升级数据库的版本。这个在这就不介绍了,以后会拓展。重点在介绍java的使用。

5、当然flyway也提供了插件支持.

有如下插件支持:Maven, Gradle,SBT和Ant,还有更多Plugins,提供对Spring Boot, Dropwizard, Grails, Play,Griffon, Grunt, Ninja 的支持。其中可以研究下flyway-test-extensions,有Usage flyway dbunit test、Usage-flyway-spring-test 功能很强大。

6、在maven项目里面的spring mvc里面使用flyway在系统启动的时候去检查并升级数据库的版本。

6.1、引入flyway的jar包,在pom.xml里面内容如下:

<!-- flyway依赖 -->

<dependency>

<groupId>org.flywaydb</groupId>

<artifactId>flyway-core</artifactId>

<version>3.0</version>

</dependency>

6.2、编写数据库的版本的脚本文件,放到src/main/resources的flyway里面:

(flyway找脚本的时候默认去src/mian/resources下面的db/migration,如果要放

在别的位置,后面的地方要配置一下)

6.3、定义在应用启动时自动运行Flyway的Java 类,并实现其逻辑代码

package com.ibm.flyway;

importjavax.sql.DataSource;

importorg.flywaydb.core.Flyway;

import org.flywaydb.core.api.FlywayException;

public classFlywayMigration {

private DataSource dataSource;

public void setDataSource(DataSourcedataSource) {

this.dataSource = dataSource;

}

public void migrate() {

Flyway flyway = new Flyway();

flyway.setDataSource(dataSource);

flyway.setLocations("db/migration"); // 设置flyway扫描sql升级脚本、java升级脚本的目录路径或包路径(表示是src/main/resources/flyway下面,前缀默认为src/main/resources,因为这个路径默认在classpath下面)

flyway.setEncoding("UTF-8");  // 设置sql脚本文件的编码

flyway.setOutOfOrder(true);

//flyway.setDataSource(dataSource);

//flyway.setSchemas("flywaydemo"); // 设置接受flyway进行版本管理的多个数据库

//flyway.setTable("schema_version"); // 设置存放flyway metadata数据的表名

//flyway.setValidationMode(ValidationMode.ALL); // 设置执行migrate操作之前的validation行为

//flyway.setValidationErrorMode(ValidationErrorMode.FAIL); // 设置当validation失败时的系统行为

// 设置当validation失败时的系统行为

try {

flyway.setInitOnMigrate(true);

flyway.migrate();

} catch (FlywayException e) {

flyway.repair();

e.printStackTrace();

}

}

}

6.4、设置在系统启动是自动运行FlywayMigration类的migrate方法

在ApplicationContext.xml(spring mvc的上下文中加入如下:)

<!-- flayway-->

<beanid="flywayMigration1" class="com.ibm.flyway.FlywayMigration" init-method="migrate">

<property name="dataSource"ref="dataSource" />

</bean>

从上面的bean 定义中我们可以看到,我们为flywayMigration 这个bean 实例注入了一个数据源,Flyway 的所有操作将针对这个数据源进行;同时我们通过init-method 属性指定了Spring 在实例化该bean 以后,主动执行该bean 的migrate 方法,而该方法内会执行Flyway 更新数据库的操作。

至此,我们达到了在应用启动时,Spring 实例化上下文的时候,在Spring 实例化flywayMigration 这个bean 的时候,自动执行Flyway 更新数据库的操作。

但是,我们还没有达到目的,万一Flyway 还在更新数据库,没有完成更新操作之前,应用程序的其他逻辑已经开始使用数据库进行其他操作了,会导致应用程序产生很多bug ,甚至根本运行不起来。

要解决这个问题,我们可以利用Spring 的bean 依赖原理,让关键的数据库操作bean 依赖于flywayMigration 这个bean ,达到在flywayMigration 没有实例化完成(数据库更新操作完成)之前,不能进行任何其他数据库相关操作。

利用Spring 的bean 依赖让flywayMigration 优先处理数据库更新操作:

<!-- 将连接池注入到 JdbcTemplate对象 -->

<beanid="jdbcTemplate"class="org.springframework.jdbc.core.JdbcTemplate"depends-on="flywayMigration1">

<property name="dataSource"ref="dataSource"></property>

</bean>

至此,运行就可以了。

但是值得注意的是:

在启动的tomcat的时候,内容如下:

但是在schema_version里面已经执行过的版本号如下:

如果存在V1_0_0__create.sql这个脚本时,是不会执行这个的,而是会执行V1_0_1__create.sql,因为schema_version表的version为1其实被flyway默认为v1_0_0_0版本了,所以没有执行。原因是schema_version表的version为1其实被flyway默认为v1_0_0版本了,所以没有执行,而version版本为表示初始化schema_version。也就是说版本号只要不一样就会执行。

注意:sql脚本的命名规则一定要准确,按照格式去命名。

flyway的使用的更多相关文章

  1. 生产环境中,数据库升级维护的最佳解决方案flyway

    官网:https://flywaydb.org/ 转载:http://casheen.iteye.com/blog/1749916 1.  引言 想到要管理数据库的版本,是在实际产品中遇到问题后想到的 ...

  2. Flyway, 数据库Schema管理利器

    整天跟数据库打交道的程序员都知道,当数据库的Schema发生改变时是多么痛苦的事情.尤其是一个在不断开发完善的项目,随着需求变化,数据库的schema也会跟着变化,而追踪记录这些变化一向都是费时费力. ...

  3. Spring Boot项目使用Flyway

    Purpose 开发人员在合作的时候经常遇到以下场景: 1.开发人员A在自己的本地数据库做了一些表结构的改动,并根据这些改动调整了DAO层的代码,然后将代码上传到svn或git等版本控制服务器上.此时 ...

  4. 快速掌握Flyway

    什么是Flyway? Flyway is an open-source database migration tool. It strongly favors simplicity and conve ...

  5. Spring Boot flyway的启动时机比较早

    flyway,如果已经创建的版本V1中已经更新,则会validation报错 at org.springframework.boot.devtools.restart.RestartLauncher. ...

  6. How to use JDBC-Authentication of Spring Boot/Spring Security with Flyway

    java.lang.IllegalStateException: Failed to load ApplicationContext at org.springframework.test.conte ...

  7. Java敏捷数据库迁移框架——Flyway

    1.引言 想到要管理数据库的版本,是在实际产品中遇到问题后想到的一种解决方案,当时各个环境的数据库乱作一团,没有任何一个人(开发.测试.维护人员)能够讲清楚当前环境下的数据库是哪个版本,与哪个版本的应 ...

  8. 数据库版本管理工具Flyway(4.0.3)---工作机制(译文)

    How Flyway works The easiest scenario is when you point Flyway to an empty database. 最容易的方案是Flyway指向 ...

  9. 数据库版本管理工具Flyway(4.0.3)---介绍(译文)

    Flyway Evolve your Database Schema easily and reliably across all your instances 简单的.可靠的升级(发展)你的数据库模 ...

  10. 微服务架构 - SpringBoot整合Jooq和Flyway

    在一次学习分布式跟踪系统zipkin中,发现了jooq这个组件,当时不知这个组件是干嘛的,后来抽空学习了一下,感觉这个组件还挺用的.它主要有以下作用: 通过DSL(Domain Specific La ...

随机推荐

  1. [源码解析] PyTorch 流水线并行实现 (1)--基础知识

    [源码解析] PyTorch 流水线并行实现 (1)--基础知识 目录 [源码解析] PyTorch 流水线并行实现 (1)--基础知识 0x00 摘要 0x01 历史 1.1 GPipe 1.2 t ...

  2. 解析Markdown文件生成React组件文档

    前言 最近做的项目使用了微前端框架single-spa. 对于这类微前端框架而言,通常有个utility应用,也就是公共应用,里面是各个子应用之间可以共用的一些公共组件或者方法. 对于一个团队而言,项 ...

  3. PHP中使用if的时候为什么建议将常量放在前面?

    在某些框架或者高手写的代码中,我们会发现有不少人喜欢在进行条件判断的时候将常量写在前面,比如: if(1 == $a){ echo 111; } 这样做有什么好处呢?我们假设一个不小心的粗心大意,少写 ...

  4. git tag标签

    列出标签 # 默认按字母排序显示 $ git tag # 模糊匹配查找标签 $ git tag -l "v2.8.5*" 创建标签 # 创建附注标签 $ git tag -a v1 ...

  5. JS HTML5仿微信朋友圈特效

    完美! 图片相册翻页可定位在第几张,右上角可关闭. 源代码下载地址: 链接: https://pan.baidu.com/s/1o7PA7wu 密码: asyt

  6. mysql给数据库表里某个字段赋随机值

    UPDATE sxz_goods set sales_volume_base = round(rand() * 50) + 1 where sales_volume_base =0 ORDER BY ...

  7. Jmeter系类(32) - JSR223(2) | Groovy常见内置函数及调用

    常见内置函数及调用 获取相关函数 获取返回数据并转换为String字符串 prev.getResponseDataAsString() 例子 String Responsedata = prev.ge ...

  8. Linux系列(31) - rpm命令管理之升级与卸载命令(3)

    升级命令 rpm -Uvh 包全名(要升级到的软件版本),如果没有安装这个软件的任何版本,这个命令可以代替rpm -ivh. rpm -Uvh 包全名 选项: - -U(upgrade):升级 卸载命 ...

  9. Charles的breakpoint功能

    修改请求报文 比如,前端已经控制了输入内容,而我们需要验证接口是否做了校验,这时候怎么测试? 可以通过charles抓包,修改请求报文,修改为在页面上无法输入的内容,发出去然后看后台怎么处理. 修改返 ...

  10. Jemter请求乱码解决方案

    1:jemeter查看结果树乱码 (1)在jmeter的bin目录下找到jmeter.properties这个文件,添加上 sampleresult.default.encoding=utf-8 (2 ...