以代码的形式实现flyway的迁移

本文介绍了一种使用Flyway进行数据库迁移的配置方法,通过Spring Boot应用中的自定义配置类,实现了对数据库版本控制和迁移的自动化处理。该配置适用于以jar包形式依赖的项目,确保了数据库更新的一致性和效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

如果某个项目被另一个项目以jar包的形式依赖,此项目的flyway实现如下

 1 package com.enmo.dbaas.firewall.common.config;
 2 
 3 import org.flywaydb.core.Flyway;
 4 import org.flywaydb.core.api.configuration.FluentConfiguration;
 5 import org.springframework.stereotype.Component;
 6 import com.enmo.dbaas.firewall.common.utils.SpringContextProvider;
 7 import lombok.extern.slf4j.Slf4j;
 8 
 9 /**
10  * @ClassName: FlywayConfig.java
11  * @Description:
12  * @Author guo.yu
13  * @Version V1.0.0
14  * @Date 2019-05-12 19:46:10
15  */
16 @Component
17 @Slf4j
18 public class FlywayConfig {
19 
20     private static final String FLYWAY_TAB_NAME = "dbaas_firewall_flyway_schema_history";
21     
22     private static final String FLYWAY_LOCATION = "db/firewall/migration";
23 
24     public FlywayConfig(SpringContextProvider provider) {
25         Flyway defFlyway = null;
26         try {
27             defFlyway = provider.getBean(Flyway.class);
28         } catch (Exception e) {
29             log.warn("flyway is not enabled.");
30         }
31         if (defFlyway != null) {
32             firewallMigrate(defFlyway);
33         }
34 
35     }
36 
37     @SuppressWarnings("deprecation")
38     public void firewallMigrate(Flyway defFlyway) {
39         FluentConfiguration config = new FluentConfiguration();
40 
41         config.dataSource(defFlyway.getDataSource())
42                .baselineOnMigrate(defFlyway.isBaselineOnMigrate())
43                .locations(FLYWAY_LOCATION)
44                .table(FLYWAY_TAB_NAME)
45                //允许运行之前版本(相对于schema表最新版本)的schema文件
46                .outOfOrder(true)
47                .load()
48                .migrate();
49         
50         
51     }
52 
53 }

 

转载于:https://www.cnblogs.com/guoAIrong/p/11417687.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值