Flyway入门使用

Flyway入门使用

官网:https://flywaydb.org/

导入jar包

<!-- flyway -->
<dependency>
	<groupId>org.flywaydb</groupId>
	<artifactId>flyway-core</artifactId>
</dependency>
<!-- flyway 插件 可有可无-->
<plugin>
   <groupId>org.flywaydb</groupId>
   <artifactId>flyway-maven-plugin</artifactId>
	 <configuration>
	 <user>root</user>
	 <password>1234500</password>
	 <driver>com.mysql.cj.jdbc.Driver</driver>
	 <url>jdbc:mysql://127.0.0.1:3306/test?useUnicode=true&amp;characterEncoding=UTF8&amp;useJDBCCompliantTimezoneShift=true&amp;useLegacyDatetimeCode=false&amp;serverTimezone=Asia/Shanghai&amp;useSSL=false</url>
 <baselineOnMigrate>true</baselineOnMigrate>
 <!--//sql脚本位置,flyway会自动去找到这个目录并且执行里面的sql脚本-->
		<locations>classpath:db/migration/</locations>
	</configuration>
 </plugin>

配置yml文件

spring:
  flyway:
    url: jdbc:mysql://127.0.0.1:3306/flyway?useUnicode=true&characterEncoding=UTF8
    user: root
    password: 自己的
    # 启用或禁用 flyway
    enabled: true
    # flyway 的 clean 命令会删除指定 schema 下的所有 table, 生产务必禁掉。这个默认值是 false 理论上作为默认配置是不科学的。
    clean-disabled: true
    # SQL 脚本的目录,多个路径使用逗号分隔 默认值 classpath:db/migration
    locations: classpath:db/migration
    #  metadata 版本控制信息表 默认 flyway_schema_history
    table: flyway_schema_history
    # 如果没有 flyway_schema_history 这个 metadata 表, 在执行 flyway migrate 命令之前, 必须先执行 flyway baseline 命令
    # 设置为 true 后 flyway 将在需要 baseline 的时候, 自动执行一次 baseline。
    baseline-on-migrate: true
    # 指定 baseline 的版本号,默认值为 1, 低于该版本号的 SQL 文件, migrate 时会被忽略
    baseline-version: 1
    # 字符编码 默认 UTF-8
    encoding: UTF-8
    # 是否允许不按顺序迁移 开发建议 true  生产建议 false
    out-of-order: true
    # 需要 flyway 管控的 schema list,这里我们配置为flyway  缺省的话, 使用spring.datasource.url 配置的那个 schema,
    # 可以指定多个schema, 但仅会在第一个schema下建立 metadata 表, 也仅在第一个schema应用migration sql 脚本.
    # 但flyway Clean 命令会依次在这些schema下都执行一遍. 所以 确保生产 spring.flyway.clean-disabled 为 true
    schemas: flyway
    # 执行迁移时是否自动调用验证   当你的 版本不符合逻辑 比如 你先执行了 DML 而没有 对应的DDL 会抛出异常
    validate-on-migrate: true

添加文件夹

一 。在resources下建个db文件
然后再db文件下再建个migration文件这个文件就是用来放.sql文件的。
二。如果你不想这样建文件,你要在yml文件更改配置
# SQL 脚本的目录,多个路径使用逗号分隔 默认值 classpath:db/migration
locations: classpath:自己的文件名
三 。如果在创建springBoot项目时的Dependencies层中加了Flyway它会自动创建db.migration文件
注:在SQL加Flyway Migration

添加sql文件到db/migration
如果没有添加在启动项目时会报错。
文件可在数据库生成,右击表选择转储SQL文件
文件命名规则

V(Versioned Migrations):
每个文件只会被执行一次
version必须唯一,可以用递增的整型和点(.)组合 例:V1.0.0__Add_table_bd_article.sql

启动项目
诺一切正常将在数据库生成一个
flyway_ schema_history(架构历史记录表)

数据库修改时
再建一个sql文件将要更改的东西写在新的sql文件里,老版sql文件的东西不要改任何东西,否者会包错。
例:V1.0.1 __ Add _ table _ bd _ article.sql将版本号加一。
包错笔记
1.如果你的SQL脚本运行失败,到schema_version表中删除version版本相同的记录。

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Flyway是一个开源的数据库版本控制工具,它允许你在应用程序的不同数据库版本之间轻松进行迁移。以下是使用Flyway的一般步骤: 1. 下载并安装Flyway:你可以从Flyway官方网站(https://flywaydb.org/)下载适合你的操作系统的Flyway二进制文件,并按照它们的文档进行安装。 2. 创建数据库:在开始使用Flyway之前,你需要先创建一个目标数据库。这可以通过使用你喜欢的数据库管理工具(如MySQL Workbench、PostgreSQL等)来完成。 3. 设置数据库连接配置:在你的应用程序中,你需要配置数据库连接信息,包括数据库URL、用户名和密码。这些信息将用于Flyway与目标数据库进行通信。 4. 创建迁移脚本:在你的应用程序中创建一个名为"db/migration"的目录(如果它不存在)。在这个目录下,你可以创建一系列以V开头的迁移脚本文件,例如"V1__create_table.sql"。这些文件将按照命名规则按顺序执行。 5. 执行迁移:当你准备好迁移脚本后,你可以使用Flyway命令行工具或集成它到你的应用程序中来执行迁移。Flyway将自动检测并执行尚未应用到目标数据库的迁移脚本。 6. 更新数据库版本:当迁移成功执行后,Flyway将会在目标数据库中记录已应用的迁移脚本,以及它们的版本号。这样,下次你运行Flyway时,它将自动忽略已应用的迁移脚本,只会执行未应用的新脚本。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值