服务器之家

服务器之家 > 正文

java开发flyway的方法

时间:2020-07-25 12:30     来源/作者:幕友皎敖奔乾

FlyWay官网:https://flywaydb.org/getstarted/firststeps/maven

Flyway做为database migration开源工具,功能上像是Git、svn这种代码版本控制。google搜索database migration,或者针对性更强些搜索database migration Java,会有其它的framework、tool、甚至aws的service。因为项目使用到了flyway,而且确实google中排第一位的搜索结果就是flyway,那就之后有机会再与其它方案做比较,先对flyway做下学习笔记。

数据库版本管理工具

什么是数据库版本管理?

做过开发的小伙伴们都知道,实现一个需求时,一般情况下都需要设计到数据库表结构的修改。那么我们怎么能保证项目多人开发时,多个数据库环境(测试,生产环境)能够保持一致呢?在没有数据库版本管理工具之前,需要将数据库修改脚本拷贝到每个数据库环境进行执行。而有了数据库版本管理工具之后,程序在启动的时候就会根据实现定义好的规则来进行数据库脚本的执行。

使用flyway

使用环境

#用的是springboot项目,mysql数据库

导入flayway和mysql依赖

java" id="highlighter_879866">
?
1
2
3
4
5
6
7
8
9
10
11
12
<dependency>
 <groupId>org.flywaydb</groupId>
 <artifactId>flyway-core</artifactId>
</dependency>
<dependency>
 <groupId>mysql</groupId>
 <artifactId>mysql-connector-java</artifactId>
</dependency>
<dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>

创建数据库脚本目录

在resources资源目录下创建db/migration目录。

添加数据库脚本

?
1
2
3
4
5
6
7
8
9
10
11
12
13
#脚本命名规则 V<VERSION>__<NAME>.sql,P<VERSION>__<NAME>.sql。V代表只执行一次,P代表可以执行多次
#VERSION代表数据库脚本版本,NAME代表数据名称。
 
#这里使用V1_test.sql,脚本内容如下所示。
 
DROP TABLE IF EXISTS `role`;
CREATE TABLE `role` (
 `id` int(11) NOT NULL,
 `name` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
 PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
 
INSERT INTO `role` VALUES (1, '1');

properties文件配置

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
#指定数据库脚本为UTF-8, flyway的配置有很多,有兴趣的小伙伴可以去看下
spring.flyway.encoding=utf-8
 
#如果原来的数据库不为空,则需要设置
spring.flyway.baseline-on-migrate=true
 
#设置数据库起始版本为0,默认为1。如果你写的sql脚本version小于等于起始版本则不会执行。
spring.flyway.baseline-version=0
 
#数据源配置
spring.datasource.url=jdbc:mysql://127.0.0.1/test?useUnicode=true&characterEncoding=utf8&useSSL=false
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.username=root
spring.datasource.password=123456

启动应用程序,查看控制台输出

java开发flyway的方法

数据库查看

java开发flyway的方法

此时flyway会默认添加一张记录数据库版本信息的表,每次启动时会根据version值判断是否需要执行sql。

flyway是怎么执行的?

?
1
2
#spring-boot-dependencies 导入了flyway,mysql依赖。
#spring-boot-autoconfigure 中导入了FlywayAutoConfiguration自动配置类

到此这篇关于java开发flyway的方法的文章就介绍到这了,更多相关java开发flyway内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://www.cnblogs.com/chenhaoblog/archive/2020/07/25/13375351.html

标签:

相关文章

热门资讯

2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
歪歪漫画vip账号共享2020_yy漫画免费账号密码共享
歪歪漫画vip账号共享2020_yy漫画免费账号密码共享 2020-04-07
男生常说24816是什么意思?女生说13579是什么意思?
男生常说24816是什么意思?女生说13579是什么意思? 2019-09-17
沙雕群名称大全2019精选 今年最火的微信群名沙雕有创意
沙雕群名称大全2019精选 今年最火的微信群名沙雕有创意 2019-07-07
玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分
玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分 2019-06-21
返回顶部