热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

SpringBoot使用flyway

SpringBoot版本2.1.17<parent><groupId>org.springframework.boot<groupId><

Spring Boot 版本 2.1.17


org.springframework.boot
spring-boot-starter-parent
2.1.17.RELEASE

pom.xml引入flyway的依赖



org.flywaydb
flyway-core

application-dev.yml 配置flyway (数据库:local_test_db)

spring:
datasource:
druid:
driver-class-name: com.mysql.jdbc.Driver
url: jdbc:mysql://localhost:3306/local_test_db?useUnicode=true&characterEncoding=UTF-8&serverTimezOne=UTC&allowPublicKeyRetrieval=true&verifyServerCertificate=false&useSSL=false&autoRecOnnect=true&failOverReadOnly=false
username: root
password: 12345678
flyway:
# 如果启动的时候需要flyway管理sql脚本的话,将enabled设置为true
enabled: true
# 如果数据库不是空表,需要设置成 true,否则启动报错
baseline-on-migrate: true
# 验证错误时 是否自动清除数据库 高危操作!
clean-on-validation-error: false

在resources目录中新建文件夹migration,用于存放sql脚本。

sql 文件所在目录:resources/db/migration (无需配置,Springboot会自动识别migration目录中的文件)

操作一:引入V1.0.1__schema.sql (创建表user)

DROP TABLE IF EXISTS user;
CREATE TABLE IF NOT EXISTS user (
id integer primary key auto_increment,
name VARCHAR(32),
address VARCHAR(64)
)
ENGINE = InnoDB
COMMENT = 'Table User';

以上sql语句执行成功之后,数据库会出现2张表

操作2:引入V1.0.2__schema.sql (创建表selected_track_index)

-- Table selected_track_index
DROP TABLE IF EXISTS selected_track_index;
CREATE TABLE IF NOT EXISTS selected_track_index (
id INTEGER PRIMARY KEY AUTO_INCREMENT,
key_name VARCHAR(64),
key_value VARCHAR(64)
) ENGINE=INNODB COMMENT='Selected Tracks.';

运行Springboot Application,成功之后,刷新Tables会出现3张表,包括新建的表"selected_track_index"。

操作3:引入V1.0.3__insert_data.sql (user表中插入1条数据)

3.1 插入出错

INSERT INTO `user` (`id`, `name`, `address`) VALUES
(1 'Bill', 'Shanghai'); # 1后面少量逗号,sql语句错误。

插入sql语句有语法错误,V1.0.3__insert_data.sql执行失败。但是数据库中的表flyway_schema_history依旧发生变化。

success 的值为0,表示执行失败。此时,更新V1.0.3__insert_data.sql,纠正sql语句。

INSERT INTO `user` (`id`, `name`, `address`) VALUES
(1, 'Bill', 'Shanghai');

虽然sql语句被纠正了,但是运行SpringBoot Application时还是会报错。

备注:`` 是有必要的,否则会报错。(flyway执行以下sql语句时会报错

INSERT INTO user (id, name, address) VALUES
(1, 'Bill', 'Shanghai');

3.1 插入正确

问题解决步骤:

1. 删除flyway_schema_history中第3条错误记录。

delete FROM flyway_schema_history WHERE installed_rank = 3;

2. 运行Springboot项目,V1.0.3__insert_data.sql被成功执行。

success 的值为1,表示执行成功。user表成功插入数据

小总结:运行错误时,删除flyway_schema_history 中的错误记录,重新运行项目即可。

参考

1. flyway使用简介

2. Flyway详解以及Springboot集成Flyway(转)


推荐阅读
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文介绍了在SpringBoot中集成thymeleaf前端模版的配置步骤,包括在application.properties配置文件中添加thymeleaf的配置信息,引入thymeleaf的jar包,以及创建PageController并添加index方法。 ... [详细]
  • eclipse学习(第三章:ssh中的Hibernate)——11.Hibernate的缓存(2级缓存,get和load)
    本文介绍了eclipse学习中的第三章内容,主要讲解了ssh中的Hibernate的缓存,包括2级缓存和get方法、load方法的区别。文章还涉及了项目实践和相关知识点的讲解。 ... [详细]
  • r2dbc配置多数据源
    R2dbc配置多数据源问题根据官网配置r2dbc连接mysql多数据源所遇到的问题pom配置可以参考官网,不过我这样配置会报错我并没有这样配置将以下内容添加到pom.xml文件d ... [详细]
  • iOS超签签名服务器搭建及其优劣势
    本文介绍了搭建iOS超签签名服务器的原因和优势,包括不掉签、用户可以直接安装不需要信任、体验好等。同时也提到了超签的劣势,即一个证书只能安装100个,成本较高。文章还详细介绍了超签的实现原理,包括用户请求服务器安装mobileconfig文件、服务器调用苹果接口添加udid等步骤。最后,还提到了生成mobileconfig文件和导出AppleWorldwideDeveloperRelationsCertificationAuthority证书的方法。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • Android系统移植与调试之如何修改Android设备状态条上音量加减键在横竖屏切换的时候的显示于隐藏
    本文介绍了如何修改Android设备状态条上音量加减键在横竖屏切换时的显示与隐藏。通过修改系统文件system_bar.xml实现了该功能,并分享了解决思路和经验。 ... [详细]
  • flowable工作流 流程变量_信也科技工作流平台的技术实践
    1背景随着公司业务发展及内部业务流程诉求的增长,目前信息化系统不能够很好满足期望,主要体现如下:目前OA流程引擎无法满足企业特定业务流程需求,且移动端体 ... [详细]
  • 本文介绍了Android 7的学习笔记总结,包括最新的移动架构视频、大厂安卓面试真题和项目实战源码讲义。同时还分享了开源的完整内容,并提醒读者在使用FileProvider适配时要注意不同模块的AndroidManfiest.xml中配置的xml文件名必须不同,否则会出现问题。 ... [详细]
  • 在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板
    本文介绍了在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板的方法和步骤,包括将ResourceDictionary添加到页面中以及在ResourceDictionary中实现模板的构建。通过本文的阅读,读者可以了解到在Xamarin XAML语言中构建控件模板的具体操作步骤和语法形式。 ... [详细]
  • web.py开发web 第八章 Formalchemy 服务端验证方法
    本文介绍了在web.py开发中使用Formalchemy进行服务端表单数据验证的方法。以User表单为例,详细说明了对各字段的验证要求,包括必填、长度限制、唯一性等。同时介绍了如何自定义验证方法来实现验证唯一性和两个密码是否相等的功能。该文提供了相关代码示例。 ... [详细]
  • 本文介绍了使用cacti监控mssql 2005运行资源情况的操作步骤,包括安装必要的工具和驱动,测试mssql的连接,配置监控脚本等。通过php连接mssql来获取SQL 2005性能计算器的值,实现对mssql的监控。详细的操作步骤和代码请参考附件。 ... [详细]
  • 延迟注入工具(python)的SQL脚本
    本文介绍了一个延迟注入工具(python)的SQL脚本,包括使用urllib2、time、socket、threading、requests等模块实现延迟注入的方法。该工具可以通过构造特定的URL来进行注入测试,并通过延迟时间来判断注入是否成功。 ... [详细]
author-avatar
王倩albe
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有