使用Flyway管理数据库脚本

使用Flyway管理数据库脚本_第1张图片

 

一、使用背景
在Mybatis中对于手工建库与修改表结构是一个比较遭人诟病的一个话题,新项目中使用了flyway来构建及管理数据库版本以方便对数据库表及结构的管理操作。简单得说,修改数据库得表,数据,等操作,都用脚本来统一执行,而不直接操作数据库

 

二、啥是Flyway?
Flyway是一个简单开源数据库版本控制器(约定大于配置),主要提供migrate、clean、info、validate、baseline、repair等命令。它支持SQL(PL/SQL、T-SQL)方式和Java方式,支持命令行客户端等,还提供一系列的插件支持(Maven、Gradle、SBT、ANT等)。

官方网站:https://flywaydb.org/
 

 

三、如何配置flyway?

前提条件:我这里使用的是mysql,springboot项目,语言java

前提得有个数据库,连接到数据库,

1.导入配置(pom) 

    
     
        
            org.springframework.boot
            spring-boot-starter
        
        
            org.springframework.boot
            spring-boot-starter-test
            test
        

        
            org.springframework.boot
            spring-boot-starter-web
        
        
            org.springframework.boot
            spring-boot-devtools
            runtime
            true
        


        
            mysql
            mysql-connector-java
            runtime
        

        
            org.mybatis.spring.boot
            mybatis-spring-boot-starter
            2.1.4
        

        
            org.flywaydb
            flyway-core
        


        
            org.projectlombok
            lombok
            true
        

    

 application.yml

spring.datasource.url=jdbc:mysql://localhost:3306/myflyway
spring.datasource.username=root
spring.datasource.password=xxxx
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver

 

2. 加入配置文件

在idea 得resources文件加下创建一个db的文件加这个文件加下,放sql脚本文件

 

使用Flyway管理数据库脚本_第2张图片

 

四、看结果

使用Flyway管理数据库脚本_第3张图片

数据库中出现了根据脚本创建的两个表,tb_goods和tb_test

还有一个flyway_schema_history表,这个应该是flyway自带的运行脚本文件历史表,

自此,flyway自动管理脚本就完成啦

以后要创建表或者修改数据库数据的时候,都把脚本写成xxx.sql文件放在db/migration这个文件夹中,项目启动的时候就会自动执行

 

 

 

 

 

 

 

 

 

 

 

 

 

你可能感兴趣的:(使用Flyway管理数据库脚本)