Flyway使用初体验

  今天上班的时间调用使用了一下Flyway框架,总体知道了其使用方法,现总结如下:

        // 初始化flyway类
        Flyway flyway = new Flyway();
        // 设置加载数据库的相关配置信息
        flyway.setDataSource(dataSource);
        // 设置存放flyway metadata数据的表名,默认"schema_version",可不写
        flyway.setTable("SCHMA_VERSION");
        // 设置flyway扫描sql升级脚本、java升级脚本的目录路径或包路径,默认"db/migration",可不写
        flyway.setLocations("dataBase/sqlite");
        // 设置sql脚本文件的编码,默认"UTF-8",可不写
        flyway.setEncoding("UTF-8");

        flyway.migrate();

 

   核心类就是Flyway类,包含了一下几种主要操作

    1.migrate方法

      迁移方法,升级数据库shema版本,使其最新。

    2.validate方法

      验证schema_version表的和脚本文件的版本是否一致。

    3.repair方法

      修复。

      其实是修改了脚本文件里面的内容,导致启动时校验和和数据库里面的schema_version表里面的不一样,此时就是为了刷新这个表的校验和的,这样,就不会报错,就能继续执行下去了。其实也就是包容了脚本文件内容的变更了。

      其实,若脚本文件的改动是可认可的,可以直接修改数据库当中的校验和,这样更快捷方便。

    4.info方法

      获得当前的版本信息

    5.clean方法

      清空数据库schema的所有数据,包括表,索引,视图,函数等等一切。

    6.baseline方法

      当数据库不为空的时候,需要引进flyway框架的时候,需要调用此方法,设置基线版本,之后,从基线版本指定的数据库脚本文件开始往后续版本执行。

 

    一些属性设置

    outOfOrder  是否允许版本在中间的脚本执行。当存在版本1和版本3,而又出现版本2是,若为true,则版本2的脚本也会执行,但在schema_version表中缺是放在最后一条记录的,所以,这个要注意,一般最好这个属性就设置为false,这样避免错误。

    

    后续继续研究使用方法。

      

转载于:https://www.cnblogs.com/weiguangyue/p/9439499.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值