Spring boot集成flyway

article/2024/12/26 9:14:56

一、引入依赖(以Maven项目为例)

  1. spring boot项目首先引入数据库连接驱动依赖

    <!-- jdbc 连接依赖,如果使用了mybatis或mybatis-plus,可直接引入对应mybatis依赖 --> 
    <dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.5.1</version>
    </dependency> 
    <!-- pgsql驱动 -->
    <dependency><groupId>org.postgresql</groupId><artifactId>postgresql</artifactId><version>42.3.1</version>
    </dependency>
    

  2. 引入flyway依赖

    <dependency><groupId>org.flywaydb</groupId><artifactId>flyway-core</artifactId><version>8.0.5</version>
    </dependency>

二、创建目录

  1. 在项目资源目录resources下创建flyway脚本目录:db/migration

三、添加配置

  1. 在Spring boot项目配置文件添加flyway开关配置,及默认脚本存放目录

    spring:flyway:enabled: true    #是否启用flyway(默认true)locations: classpath:db/migration    #sql脚本文件位置

四、编写脚本

  1. 升级执行脚本,只执行一次,文件名不变就不会再次执行
    1. 前缀大写V开头;
    2. 后接版本号,一般为时间字符串,表明sql脚本创建时间,如:2022年5月30日11时29分可写为20220530112900,时间字符串从小到大决定sql脚本执行顺序;
    3. 后接两个英文下划线__;
    4. 再添加sql文件的描述,如创建表:create_table_tablename,修改表:alter_table_tablename,插入数据:insert_into_tablename,删除数据:delete_from_tablename

      eg:
      #脚本名称
      V20220527090700__create_table_test_event.sql#脚本内容
      CREATE TABLE public.test_event (id int8 GENERATED ALWAYS AS IDENTITY (cache 100) PRIMARY KEY,event_time int8 NOT NULL,event_type int4 NULL,priority int4 NULL,longitude float8 NULL,latitude float8 NULL,altitude float4 NULL,create_time timestamp NULL,latest_update_time timestamp NULL,deleted int2 DEFAULT 0
      );
      COMMENT ON COLUMN public.event_shadow.event_time IS '事件时间';
      CREATE UNIQUE INDEX uindex_sid_eventtime on public.test_event (event_time);

  2. 重复执行脚本,多次执行,文件内容变化即文件校验和变化时就会执行
    1. 前缀大写R开头;
    2. 后接两个英文下划线__;
    3. 再添加sql文件的描述,如创建表:create_table_tablename,修改表:alter_table_tablename,插入数据:insert_into_tablename,删除数据:delete_from_tablename,描述字符串字典顺序从小到大决定sql脚本执行顺序;

      eg:重复执行使用场景可用于配置更新语句,使用覆盖插入语句,每次配置更新可用同一个重复执行文件修改,而非添加一个版本升级文件
      #脚本名称
      R__insert_into_test_event.sql


http://chatgpt.dhexx.cn/article/N73DUcIS.shtml

相关文章

开发flyray的初衷

开发flyray的初衷 一是为了自我学习&#xff0c;二是为了方便项目开发flyray项目介绍 使用SpringSpringMVCMybatisdubbox 开发的一套分布式基础框架&#xff0c;提供支付、对账、清结算、客户管理、营销活动、库存管理、搜索模块、rocketmq做统一的消息队列中心 使用技术 后…

flyway

需求&#xff1a; 目前环境太多套&#xff0c;而且每套的代码版本都是不一致的&#xff0c;再分支升级版本的时候每次都需要处理数据库的sql脚本&#xff0c;用人工核对容易出错或遗漏&#xff0c;为避免sql脚本混乱&#xff0c;需要统一的数据版本工具来进行维护。当前公司生…

springboot:集成flyway

文章目录 springboot&#xff1a;集成flyway一、简介二、Flyway工作流程三、配置文件使用Flyway添加相关配置创建脚本所在文件夹sql脚本命名规范启动测试 四、Flyway配置清单五、maven插件的使用migratebaselineclean&#xff08;慎用&#xff09;inforepairvalidateundo 六、f…

Firefly

Firefly(流萤): 中文对话式大语言模型在本文中&#xff0c;笔者将介绍关于Firefly&#xff08;流萤&#xff09;模型的工作&#xff0c;一个中文对话式大语言模型。https://mp.weixin.qq.com/s/TX7wj8IzD_EaMTvk0bjRtA一个支持中文的176B开源基础模型BLOOM&#xff1a;从数据源…

RIP 水平分割

水平分割 为了防止环路,RIP引入了水平分割机制,即从一个接口收到的路由更新,不会再从这个接口发出去,水平分割默认开启. 实验&#xff1a;RIP的水平分割 首先我们先查看R1和R3的路由表有什么异常

RIP水平分割实验

华为RIP水平分割实验 为了防止环路&#xff0c;BIP引入了水平分割机制&#xff0c;即从一个接口收到得路由更新&#xff0c;不会在从这个接口发出去&#xff0c;水平分割默认开启 实验拓补图如下 首先配置R1 system view [Huawei]sysname R1 [R1]int g0/0/0 [R1-Gigabi…

路由协议BGP之打破IBGP水平分割✍

为什么需要打破IBGP的水平分割&#xff1f; 因为IBGP水平分割&#xff0c;导致在一个AS内部若一台BGP路由器需要将通过其他AS学习到的路由传递给本地AS中的ibgp邻居时&#xff0c;需要和本地AS内部所有的BGP设备建立IBGP邻居关系&#xff1b;邻居关系数量成指数上升&#xff1…

解决IBGP的水平分割和BGP选路原则

解决IBGP的水平分割问题 IBGP水平分割&#xff1a;防止环路的产生 方法1&#xff1a;路由反射器(RR) 路由反射器可以反射所学习到的IBGP路由信息。 指定一台路由器称为 路由反射器&#xff08;RR&#xff09; 的时&#xff0c;必须在他的IBGP对等体关系中选择一个或者多个设备…

html中怎么接着水平线后面,html水平分割线怎么设置?html水平分割线的代码示例讲解...

在前端网页的开发中我们有时候需要用到水平分割线来分割不同的文档&#xff0c;会让整个网页看起来美观和整洁&#xff0c;也会凸显某一段文字的重要性&#xff0c;那么网页中水平分割线该如何实现呢&#xff1f; 本篇文章就给大家来分享一下html水平分割线的实现方法。 在html…

基于WPS的Word最佳实践系列(给标题添加水平分割线)

基于WPS的Word最佳实践系列&#xff08;给标题添加水平分割线&#xff09; 项目背景 在日常办公中&#xff0c;我们经常需要给标题添加一条水平分割线&#xff0c;将标题与正文内容分开&#xff0c;那么如何快速添加水平分割线呢&#xff1f; 项目实施 1. 添加水平分割线 …

5.2 BGP水平分割

5.2.2实验2&#xff1a;BGP水平分割 1. 实验目的 熟悉BGP水平分割的应用场景掌握BGP水平分割的配置方法 2. 实验拓扑 实验拓扑如图5-2所示&#xff1a; 图5-2&#xff1a;BGP水平分割 3. 实验步骤 &#xff08;1&#xff09;配置IP地址 R1的配置 <Huawei&g…

图像分割之水平集(Level Set)分割

几何活动轮廓模型——水平集分割&#xff1a;Active Contours Without Edges 水平集方法 水平集是跟踪轮廓和表面运动的一种数字化方法&#xff0c;它不直接对轮廓进行操作&#xff0c;而是将轮廓设置成一个高维函数的零水平集。这个高维函数叫做水平集函数。然后对该水平集函数…

BGP选路——本地优先级选路(+BGP路由水平分割机制)

目录 一、本地优先级特性 二、配置命令&#xff1a; 三、图解&#xff1a; 四、BGP路由水平分割机制 BGP路由13条选路顺序&#xff1a; 权重——本地优先级——本地始发——最短AS-PATH——起源属性——MED属性——EBGP路由优于IBGP——八——九——十——十一——十二——…

html文字段落分割,HTML设置水平分割线_html/css_WEB-ITnose

在Web中使用水平分割线可以分割不同的文字段落或者其它网页组件&#xff0c;轻松地修饰了段落排版&#xff0c;使之更美观。当然&#xff0c;水平分割线还可以更加明显地突出某一段重要的文字&#xff0c;使之更加醒目。 使用标签可以轻松地设置一条水平线。方法如下&#xff1…

初步了解BGP-2【update-source、水平分割、同步概念】

初步了解BGP-2【update-source、水平分割、同步概念】 目录 初步了解BGP-2【update-source、水平分割、同步概念】Update-sourceIBGP 水平分割IBGP与IGP的同步 Update-source 由于BGP无法像IGP那样自动发现邻居&#xff0c;而BGP的邻居需要手动指定邻居&#xff0c;一般情况下…

html分割线颜色怎么在css中写,html水平分割线 html 分割线颜色怎么变浅

深入理解es6和es6标准入门哪本好 Dubbo的分布式系统架构实战需要哪些步骤完成 HTML如何添加水平分割线: HTML提供了修饰段落的水平分割线&#xff0c;在很多的网页布局中都可以轻松使用&#xff0c;而不需要另外作图。水平分割线的标签是单标签&#xff1a; 默认情况下只占一行…

水平集分割

基于距离正则的水平集分割MATLAB代码&#xff0c;无需初始化 % This Matlab code demonstrates an edge-based active contour model as an application of % the Distance Regularized Level Set Evolution (DRLSE) formulation in the following paper: % % C. Li, C. X…

图像分割 - 水平集算法

水平集介绍 水平集分为三种&#xff1a; 1 . 基于图像边缘灰度梯度信息 &#xff0c;适用于边缘强的图像分割 2 . 基于区域特征 &#xff0c;利用区域信息引导曲线慢慢靠近 &#xff0c;比如分割曲线区域的内外灰度均值&#xff0c;分割曲线内部区域面积&#xff08;例如 Ch…

IBGP水平分割

IBGP水平分割规则 IBGP水平分割用于在IBGP对等体之间进行路由传递时&#xff0c;无法像EBGP对等体那样一来AS-Path属性进行防止环路的问题&#xff0c;因为AS-Path属性在AS内进行传递时是不会发生改变的。 下图便是极有可能出现IBGP对等体环路的场景&#xff1a; R1将10.1.1.…

垂直分割和水平分割

2019独角兽企业重金招聘Python工程师标准>>> 1&#xff0c;水平分割&#xff1a; 例&#xff1a;QQ的登录表。假设QQ的用户有100亿&#xff0c;如果只有一张表&#xff0c;每个用户登录的时候数据库都要从这100亿中查找&#xff0c;会很慢很慢。如果将这一张表分成1…