SpringBoot项目集成Flyway进行数据库版本控制的详细教程

 更新时间:2020年07月25日 09:19:19   作者:Cug_wangww  
这篇文章主要介绍了SpringBoot项目集成Flyway进行数据库版本控制,本文分步骤通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

Flyway是一款开源的数据库版本管理工具,它更倾向于规约优于配置的方式。

第一步:pom.xml添加maven依赖

<!-- https://mvnrepository.com/artifact/org.flywaydb/flyway-core -->
<dependency>
	<groupId>org.flywaydb</groupId>
	<artifactId>flyway-core</artifactId>
	<version>5.0.7</version>
</dependency>

第二步:开启Flyway支持,在application.properties文件添加Flyway配置

# FLYWAY (FlywayProperties)
flyway.baseline-version=1.0.0
flyway.enabled=true
flyway.sql-migration-prefix=V
flyway.sql-migration-suffix=.sql
flyway.baseline-on-migrate=true
flyway.location=db/migration

第三步:在resource目录下创建db/migration目录添加sql脚本

验证是否成功:项目启动时,会运行flyway执行sql语句.生成schema_version表,用于记录sql执行情况.

当sql文件修改后.比如多个空格,项目启动时,该sql对应的checksum字段与表记录的不一致会报错.

注意事项:

FlywayProperties参数配置详解

flyway.baseline-version   执行基线时用来标记已有Schema的版本。(默认值:1)
flyway.enabled   开启Flyway。 (默认值: true 。 )
flyway.sql-migration-prefix  SQL迁移的文件名前缀。 (默认值: V 。 )
flyway.sql-migration-suffix  SQL迁移的文件名后缀。 (默认值: .sql 。 )
flyway.baseline-on-migrate   在没有元数据表的情况下,针对非空Schema执行迁移时是否自动调用基线。
flyway.location 迁移脚本的位置。 (默认值: db/migration 。 )

sql文件版本号命名的规范

每个公司的规范肯定不一样.开发时,只需要项目内遵循该规范即可,规范的确定并没有对错.提供一种sql文件命名规范仅供大家参考.

到此这篇关于SpringBoot项目集成Flyway进行数据库版本控制的文章就介绍到这了,更多相关SpringBoot集成Flyway数据库版本控制内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 关于SpringBoot配置文件application.properties的路径问题

    关于SpringBoot配置文件application.properties的路径问题

    这篇文章主要介绍了关于SpringBoot配置文件application.properties的路径问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • Java中Lambda表达式并行与组合行为

    Java中Lambda表达式并行与组合行为

    这篇文章主要介绍了Java中Lambda表达式并行与组合行为,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-02-02
  • Spring MVC注解式开发示例完整过程

    Spring MVC注解式开发示例完整过程

    这篇文章主要介绍了Spring MVC注解式开发示例完整过程,MVC注解式开发即处理器基于注解的类开发,对于每一个定义的处理器,无需在xml中注册,只需在代码中通过对类与方法的注解,即可完成注册
    2023-02-02
  • java_String和StringBuffer区别分析

    java_String和StringBuffer区别分析

    JAVA平台提供了两个类:String和StringBuffer,它们可以储存和操作字符串,即包含多个字符的字符数据。这个String类提供了数值不可改变的字符串。
    2013-04-04
  • Spring 中的 ResourceLoader实例详解

    Spring 中的 ResourceLoader实例详解

    Spring框架提供了ResourceLoader接口,用于加载资源文件,DefaultResourceLoader是其基本实现,只能加载单个资源,而ResourcePatternResolver继承自ResourceLoader,增加了按模式加载多个资源的能力,感兴趣的朋友一起看看吧
    2024-11-11
  • maven引入本地jar包运行报错java.lang.NoClassDefFoundError解决

    maven引入本地jar包运行报错java.lang.NoClassDefFoundError解决

    这篇文章主要为大家介绍了maven引入本地jar包运行报错java.lang.NoClassDefFoundError解决方法详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • Java Map 通过 key 或者 value 过滤的实例代码

    Java Map 通过 key 或者 value 过滤的实例代码

    这篇文章主要介绍了Java Map 通过 key 或者 value 过滤的实例代码,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-06-06
  • java实现大文件导出的实现与优化

    java实现大文件导出的实现与优化

    这篇文章主要为大家详细介绍了java实现大文件导出的实现与优化的相关资料,文中的示例代码讲解详细,对我们深入了解java有一定的帮助,感兴趣的小伙伴可以了解下
    2023-11-11
  • SpringBoot指标监控的实现

    SpringBoot指标监控的实现

    本文主要介绍了SpringBoot指标监控的实现,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09
  • 带你快速搞定java多线程(2)

    带你快速搞定java多线程(2)

    这篇文章主要介绍了java多线程编程实例,分享了几则多线程的实例代码,具有一定参考价值,加深多线程编程的理解还是很有帮助的,需要的朋友可以参考下
    2021-07-07

最新评论