今天上班的时间调用使用了一下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,这样避免错误。
后续继续研究使用方法。