springboot与flyway集成做数据迁移

    flyway是一种用来做数据迁移的框架,如果你的项目不是jpa+hibenate,比如使用的mybatis,那么你需要在实体创建之前,在数据库中生成表结构,然后逆向工程,生成实体,或者自己编码写实体类,部署的时候,需要将测试环境的表结构和部分数据导出为sql文件,部署到生产环境中,全程操作数据库都是人为操作。后续实体发生改变,字段增减,还需要单独运行一个增量的脚本,或者全量更新,这还需要人为操作。容易造成疏漏。

    但是flyway框架提供了一种版本控制的迁移策略,可以对sql进行自动的增量提交,而且减少了人为操作这一步。当我们和springboot结合的时候,他可以在项目启动的时候,进行版本检查,如果有新增或者修改,他会自动将新增或者修改的部分更新到数据库中。如果我们第一次运行,而且数据库中没有任何数据,那么可以不用担心基线版本的问题,如果第一次运行,数据库中有表结构和数据,需要考虑将数据库中的数据做一次基线版本设置。后续的所有操作都在此基础上做变更。

    下面来介绍flyway的简单使用,我们可以单独使用flyway,在maven工程中,简单配置一下,就可以做一些简单的demo了。

    先构建一个基础的maven工程,加入org.flywaydb:flyway-core依赖以及mysql-connector-java依赖,在build节点配置flyway-maven-plugin,并设置连接mysql的url,user,password信息,如下所示:

<parent>
	<groupId>org.springframework.boot</groupId>
	<artifactId>spring-boot-starter-parent</artifactId>
	<version>2.1.4.RELEASE</version>
</parent>

<dependencies>
<dependency>
  <groupId>junit</groupId>
  <artifactId>junit</artifactId>
  <scope>test</scope>
</dependency>
<dependency>
  <groupId>org.flywaydb</groupId>
  <artifactId>flyway-core</artifactId>
</dependency>
<dependency>
  <groupId>mysql</groupId>
  <artifactId>mysql-connector-java</artifactId>
</dependency>
</dependencies>

<build>
 <plugins>
	  <plugin>
		   <groupId>org.flywaydb</groupId>
		   <artifactId>flyway-maven-plugin</artifactId>
		   <configuration>
			   <url>jdbc:mysql:///flywaydemo?useSSL=false&amp;
                    useUnicode=true&amp;characterEncoding=UTF-8&amp;
                    serverTimezone=Asia/Shanghai</url>
			   <user>root</user>
			   <password>root</password>
		   </configuration>
	  </plugin>
 </p
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

luffy5459

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值