【Spring Boot 3】【Flyway】数据库版本管理

【Spring Boot 3】【Flyway】数据库版本管理

  • 背景
  • 介绍
  • 开发环境
  • 开发步骤及源码
  • 工程目录结构
  • 总结

背景

软件开发是一门实践性科学,对大多数人来说,学习一种新技术不是一开始就去深究其原理,而是先从做出一个可工作的DEMO入手。但在我个人学习和工作经历中,每次学习新技术总是要花费或多或少的时间、检索不止一篇资料才能得出一个可工作的DEMO,这占用了我大量的时间精力。因此本文旨在通过一篇文章即能还原出可工作的、甚至可用于生产的DEMO,期望初学者能尽快地迈过0到1的这一步骤,并在此基础上不断深化对相关知识的理解。
为达以上目的,本文会将开发环境、工程目录结构、开发步骤及源码尽量全面地展现出来,文字描述能简则简,能用代码注释的绝不在正文中再啰嗦一遍,正文仅对必要且关键的信息做重点描述。

介绍

Flyway是一个数据库迁移工具,简单来说就是在部署应用时执行数据库脚本的工具。
Flyway的原理就是通过一个迁移记录表(默认为 flyway_schema_history)来管理各版本数据库脚本的执行情况。
Flyway将这些数据库脚本称作Migration,分为下列三种:

  • Versioned Migration:每个版本执行一次,包含版本、描述和校验和,常用于创建、修改、删除表,或插入、修改数据等;
  • Undo Migration:Versioned Migration对应的相反操作;
  • Repeatable Migration:可执行多次,包含描述和校验和,注意没有版本,主要用于视图、存储过程、函数等。

Migration命名由五部分组成:

  • 前缀(Prefix):V 代表 Versioned Migration,U 代表 Undo Migration,R 代表 Repeatable Migration。
  • 版本号(Version):唯一版本号,如:V1.0.1
  • 分隔符(Separator):两个下划线(__
  • 描述信息
  • 后缀(Suffix):

你可能感兴趣的:(Spring,spring,boot,flyway)