服务器之家

服务器之家 > 正文

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

时间:2020-07-25 13:55     来源/作者:Cug_wangww

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

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

?
1
2
3
4
5
6
<!-- 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配置

?
1
2
3
4
5
6
7
# 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脚本

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

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

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

当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集成Flyway数据库版本控制内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/Cug_wangww/article/details/81150417

相关文章

热门资讯

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
返回顶部