文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

从零搭建开发脚手架 Spring Boot集成Flyway实现数据库版本管理

2024-12-03 09:24

关注

Flyway是一款数据库版本控制管理工具,支持数据库版本自动升级。

现在我们就可以使用flyway来帮我们自动的去完成这个工作。

Flyway集成和使用

添加依赖

  1.  
  2.   org.flywaydb  
  3.   flyway-core 
  4.  

 

由于是Spring Boot项目集成,版本直接使用默认的即可

配置文件

  1. spring: 
  2.   flyway: 
  3.     #是否开启flyway,默认true 
  4.     enabled: true 
  5.     #当迁移时发现目标schema非空,而且没有元数据的表时,(即迭代中项目)是否自动执行基准迁移,默认false
  6.     baseline-on-migrate: true 
  7.     # 是否允许无序运行迁移, 默认false,建议开发环境开启,生成环境关闭 
  8.     out-of-ordertrue 
  9.     #设定SQL脚本的目录,可以配置多个,比如为classpath:db/migration,filesystem:/sql-migrations,默认classpath:db/migration 
  10.     locations: 
  11.       - classpath:db/migration 

更多参数见 https://flywaydb.org/documentation/configfiles

“这些参数配到springboot2 项目中, 需要加上 spring前缀

脚本

在resource目录下面建立db.migration目录,放置sql文件

sql脚本的格式:

测试

默认情况下,Spring Boot在应用程序启动时自动运行Flyway数据库迁移。

结果如下:

注意:

Flyway社区版不支持MySQL5.7以下的版本了

https://flywaydb.org/documentation/database/mysql

原理

Flyway 需要在 DB 中先创建一个 metdata 表 (缺省表名为 flyway_schema_history), 在该表中保存着每次迁移的记录, 记录包含迁移脚本的版本号和 SQL 脚本的 checksum 值. 当一个新的 SQL 脚本被扫描到后, Flyway 解析该 SQL 脚本的版本号, 并和 metadata 表已执行的迁移对比, 如果该 SQL 脚本版本更新的话, 将在指定的 DB 上执行该 SQL 文件, 否则跳过该 SQL 文件.

两个 flyway 版本号的比较, 采用左对齐原则, 缺位用 0 代替. 举例如下:

Flyway SQL 文件可以分为两类:

默认情况下, Migration SQL的命名规则如下图:

img

其中的文件名由以下部分组成,除了使用默认配置外,某些部分还可自定义规则.

Flyway 的 metadata 表结果如下:

  1. CREATE TABLE  flyway_schema_history 
  2.     ( 
  3.         installed_rank INT NOT NULL
  4.         version VARCHAR(50), 
  5.         description VARCHAR(200) NOT NULL
  6.         type VARCHAR(20) NOT NULL
  7.         script VARCHAR(1000) NOT NULL
  8.         checksum INT
  9.         installed_by VARCHAR(100) NOT NULL
  10.         installed_on TIMESTAMP DEFAULT CURRENT_TIMESTAMP
  11.         execution_time INT NOT NULL
  12.         success TINYINT(1) NOT NULL
  13.         PRIMARY KEY (installed_rank), 
  14.         INDEX flyway_schema_history_s_idx (success) 
  15.     ) 
  16.     ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; 

高级

基于Java的迁移回调

Flyway使我们能够使用两种不同的方法(Java或SQL)创建回调。前者是最灵活的一种。它为我们提供了执行任意代码的自由。

核心代码如下:

  1. import lombok.extern.slf4j.Slf4j; 
  2. import org.flywaydb.core.api.callback.BaseCallback; 
  3. import org.flywaydb.core.api.callback.Context; 
  4. import org.flywaydb.core.api.callback.Event; 
  5. import org.flywaydb.core.internal.jdbc.JdbcTemplate; 
  6. import org.springframework.context.annotation.Configuration; 
  7.  
  8. import java.sql.SQLException; 
  9.  
  10. @Configuration 
  11. @Slf4j 
  12. public class ExampleFlywayCallback extends BaseCallback { 
  13.     @Override 
  14.     public void handle(Event event, Context context) { 
  15.         switch (event) { 
  16.             // 在每次成功迁移后触发。此事件将在与迁移相同的事务中触发 
  17.             case AFTER_EACH_MIGRATE: 
  18.                 log.info("{},", event); 
  19.                 final JdbcTemplate jdbcTemplate = new JdbcTemplate( 
  20.                         context.getConnection()); 
  21.  
  22.                 // Create 10 random users 
  23.                 for (int i = 1; i <= 10; i++) { 
  24.                     try { 
  25.                         jdbcTemplate.execute(String.format("insert into test_user" 
  26.                                 + " (username, first_name, last_name) values" 
  27.                                 + " ('%d@reflectoring.io', 'Elvis_%d', 'Presley_%d')", i, i, i)); 
  28.                     } catch (SQLException throwables) { 
  29.                         throwables.printStackTrace(); 
  30.                     } 
  31.                 } 
  32.         } 
  33.     } 

我们可以在Java迁移回调中执行所需的任何逻辑,可以灵活地实现更多变态需求。

参考:

https://www.cnblogs.com/harrychinese/p/springboot_flyway.html

 

https://blog.csdn.net/qq_38455201/article/details/103493041

 

来源: Java大厂面试官内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯