美文网首页
Flyway数据迁移工具使用和安装

Flyway数据迁移工具使用和安装

作者: zhuyuansj | 来源:发表于2020-03-19 10:28 被阅读0次

以前生产环境数据库增加字段是写一个sql放入本地,到时候部署生产环境的时候先手动执行sql,在部署项目。Flyway数据迁移工具主要是用来控制数据库增删改的版本控制,类似于git,可是相比git代码管理,他的版本控制是通过数据库当中的flyway_schema_history来控制的,这样每次部署生产环境的时候就不需要人工再去执行sql,部署项目的时候sql会自动执行。

先新建一个springboot项目
pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.flywaydb</groupId>
    <artifactId>flywaydb</artifactId>
    <version>1.0-SNAPSHOT</version>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.11.RELEASE</version>
        <relativePath/> <!-- lookup parent from dao -->
    </parent>
    <dependencies>
        <!-- SpringBoot-整合Web组件 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.15</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-jdbc</artifactId>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>
        <dependency>
            <groupId>org.flywaydb</groupId>
            <artifactId>flyway-core</artifactId>
            <version>5.2.4</version>
        </dependency>
        <dependency>
            <groupId>org.flywaydb</groupId>
            <artifactId>flyway-core</artifactId>
        </dependency>
    </dependencies>
</project>

application.yml配置

server:
  port: 8091
spring:
  datasource:
    url: jdbc:mysql://127.0.0.1:3306/springboot?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&rewriteBatchedStatements=true&useSSL=false&serverTimezone=GMT%2B8
    username: root
    password: root
  flyway:
    enabled: true
    # 禁止清理数据库表
    clean-disabled: true
    # 如果数据库不是空表,需要设置成 true,否则启动报错
    baseline-on-migrate: true
    # 与 baseline-on-migrate: true 搭配使用
    baseline-version: 0
    locations:
      - classpath:db/migration/mysql  #(根据个人情况设置)

再resource新建db.migration.mysql
然后创建两个文件,文件名为:版本号增删改查(Add,Create,update)表名.sql
V1__Create_test111_table.sql

create table test111 (
    ID int not null,
    NAME varchar(100) not null
);

V2__Add_test111.sql

insert into test111 (ID, NAME) values (1, 'Axel');
insert into test111 (ID, NAME) values (2, 'Mr. Foo');
insert into test111 (ID, NAME) values (3, 'Ms. Bar');

然后运行springboot项目,如果能正常启动,可以在mysql中看到以下两张表

image.png
相关文章推荐:Flyway 简单入门教程

相关文章

  • Flyway数据迁移工具使用和安装

    以前生产环境数据库增加字段是写一个sql放入本地,到时候部署生产环境的时候先手动执行sql,在部署项目。Flywa...

  • flyway使用教程

    flyway 什么是flyway flyway是一个数据库迁移工具.使用version来记录每一次脚本的执行. 使...

  • 0—flyway介绍

    Flyway是一个开源的数据库迁移工具。 它基于只有6个基本命令: 迁移, 清理, 信息, 验证, 基准和 修复。...

  • Flyway 使用手记

    Flyway简介 Flyway是一款数据库迁移(migration)工具。简单点说,就是在你部署应用的时候,帮你执...

  • Flyway

    和Liquibase一样,Flyway也是一种开源的数据库迁移工具。Liquibase的文章在这里:https:/...

  • Thinkphp6 数据迁移工具踩坑记

    查看安装列表是否有migrate,如果没有就安装数据迁移工具 php think list 安装数据迁移工具重点:...

  • 1—flyway命令概述

    1、Migrate迁移 将模式迁移到最新版本。如果Flyway不存在,则会自动创建元数据表。 迁移是Flyway工...

  • flyway使用

    官网[https://flywaydb.org/] flyway简介 Flyway是一款数据库迁移(migrati...

  • Flyway 数据库迁移工具

    一、什么是Flyway? Flyway是一款开源的数据库版本管理工具,主要是用于数据库版本管理并且跟踪数据库变更。...

  • laravel常用命令

    安装 Auth 系统 数据库迁移 使用 Artisan 工具新建 Model 类 创建table 测试数据 Fak...

网友评论

      本文标题:Flyway数据迁移工具使用和安装

      本文链接:https://www.haomeiwen.com/subject/qyekyhtx.html