当前位置:Gxlcms > 数据库问题 > Flyway - Version control for your database

Flyway - Version control for your database

时间:2021-07-01 10:21:17 帮助过:7人阅读

  Maven 3.x

编辑器:

  IDEA

数据库:

  MySQL

环境安装好之后需要新建一个Maven项目。

这里使用数据库是MySQL,如果不是MySQL也可以按照此文做,

不同的就是连接数据库的URL和数据库驱动,当然还有一些特定的配置也会不一样,但是没什么影响。

一切准备就绪之后开始Flyway的配置,以新建Person表为例。

整合Flyway

第一步

在Maven项目中引入框架或者插件或者其他工具,第一步就是修改pom.xml,引入相关的资源。

这里引入Flyway插件。

 1    <build>
 2         <plugins>
 3             <plugin>
 4                 <groupId>org.springframework.boot</groupId>
 5                 <artifactId>spring-boot-maven-plugin</artifactId>
 6             </plugin>
 7             <!--引入Flyway插件-->
 8             <plugin>
 9                 <groupId>org.flywaydb</groupId>
10                 <artifactId>flyway-maven-plugin</artifactId>
11                 <version>5.2.4</version>
12                 <configuration>
13                     <!--数据库连接URL-->
14                     <url>jdbc:mysql://localhost:3306/dbtrial?useUnicode=true&amp;characterEncoding=utf-8&amp;serverTimezone=UTC</url>
15                     <!--数据库连接用户名-->
16                     <user>root</user>
17                     <!--数据库连接密码-->
18                     <password>123</password>
19                     <!--指定数据库-->
20                     <schemas>dbtrial</schemas>
21                     <!--指定如果flyway_schema_history表不存在则新建-->
22                     <baselineOnMigrate>true</baselineOnMigrate>
23                 </configuration>
24             </plugin>
25         </plugins>
26     </build>

注意:因为在pom.xml 字符 “&” 被认作特殊字符,所以这里用 “&amp;” 

   <schemas>dbtrial</schemas>此配置是为了指定数据库中脚本在那个数据库下面执行。

     flyway_schema_history 表使用来记录执行日志的,下图是表中记录的内容,

     第一条是创建日志表,第二条是执行项目里面的SQL脚本(当然这是Flyway执行成功后才能看到的,现在提前贴出来方便理解):

   技术图片

    

  因为在创建项目时选择的是web项目,并且选了使用MySQL数据库所以已经有了MySQL的数据库驱动。

如果没有,则需要在pom.xml中添加依赖

        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>

第二步

pom.xml修改完成之后,接下来需要准备要执行的SQL脚本。

但是在新建SQL脚本之前需要先在项目中创建一个文件夹存放脚本文件。

路径:\src\main\resources\db\migration

注意:这里在创建文件夹时,Flyway默认的就是上面的路径。(虽然配置也可以修改,但是新学不建议搞得太复杂)

然后在创建好的路径下面新建SQL脚本文件

路径:\src\main\resources\db\migration\V1.1__CreatePersonTable.sql注意:文件的命名要使用推荐的格式如用V1.0、V1.1、V1.x这种格式。好处在于,

Flyway对脚本文件的命名非常敏感,格式不对可能会报错,再者就是利于查看,看文件名就能知道版本先后。

版本号后面一定要跟两个下划线。否则一直会报错文件名格式不正确。

目录结构:

技术图片

SQL脚本:

create table PERSON (
    ID int not null,
    NAME varchar(100) not null
);

第三步

万事俱备只欠东风,最后我们需要做的就是让Flyway执行起来,自动更新数据库。

打开terminal,然后输入命令:

技术图片  

执行之后的输出信息:

技术图片

 

然后查看数据库:

技术图片

 

总结

入门级文章,如有错误或者疑问欢迎指出。

Flyway的功能很强大,支持市面上非常多的数据库。

能同时执行不同数据库的脚本,支持事务等等。

深入用法可以访问官网。

 

Flyway - Version control for your database

标签:字符   ted   har   zone   用户   connector   nal   支持   过程   

人气教程排行