加入收藏 | 设为首页 | 会员中心 | 我要投稿 湖南网 (https://www.hunanwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程 > 正文

Spring Boot 2拭魅战:行使Flyway打点你数据库的版本改观

发布时间:2019-10-30 17:07:14 所属栏目:编程 来源:码农小胖哥
导读:1. 媒介 跟着项目标不绝迭代,数据库表布局、数据都在产生着变革。乃至有的营业在多情形版本并行运行。数据为王的期间,打点好数据库的版本也成为了急切的必要。怎样能做到像 Git 之类的版本节制器材来打点数据库?Java 项目中常用 Flyway 和 Liquibase 来

对应Flyway的设置为:

  1. # flyway 设置  
  2. spring:  
  3.   flyway:  
  4.     # 启用或禁用 flyway  
  5.     enabled: true  
  6.     # flyway 的 clean 呼吁会删除指定 schema 下的全部 table, 出产务必禁掉。这个默认值是 false 理论上作为默认设置是不科学的。  
  7.     clean-disabled: true  
  8.     # SQL 剧本的目次,多个路径行使逗号脱离 默认值 classpath:db/migration  
  9.     locations: classpath:db/migration  
  10.     #  metadata 版本节制信息表 默认 flyway_schema_history  
  11.     table: flyway_schema_history  
  12.     # 假如没有 flyway_schema_history 这个 metadata 表, 在执行 flyway migrate 呼吁之前, 必需先执行 flyway baseline 呼吁  
  13.     # 配置为 true 后 flyway 将在必要 baseline 的时辰, 自动执行一次 baseline。  
  14.     baseline-on-migrate: true  
  15.     # 指定 baseline 的版本号,默认值为 1, 低于该版本号的 SQL 文件, migrate 时会被忽略  
  16.     baseline-version: 1  
  17.     # 字符编码 默认 UTF-8  
  18.     encoding: UTF-8  
  19.     # 是否应承不按次序迁徙 开拓提议 true  出产提议 false  
  20.     out-of-order: false  
  21.     # 必要 flyway 管控的 schema list,这里我们设置为flyway  缺省的话, 行使spring.datasource.url 设置的谁人 schema,  
  22.     # 可以指定多个schema, 但仅会在第一个schema下成立 metadata 表, 也仅在第一个schema应用migration sql 剧本.  
  23.     # 但flyway Clean 呼吁会依次在这些schema下都执行一遍. 以是 确保出产 spring.flyway.clean-disabled 为 true  
  24.     schemas: flyway  
  25.     # 执行迁徙时是否自动挪用验证   当你的 版本不切合逻辑 好比 你先执行了 DML 而没有 对应的DDL 会抛出非常  
  26.     validate-on-migrate: true 

请务必细心阅读 Flyway 相干设置的声名。

4.3 编写 SQL 初始化剧本

我们先编写一个初始化 SQL 文件,向 H2 数据库已经自动初始化的 schema flyway 添加一张 sys_user 表。请留意定名法则。剧本名称为 V1.0.1__Add_table_user.sql 。SQL 剧本的位置在设置的 spring.flyway.locations 下。内容为:

  1. use `flyway`;  
  2. CREATE TABLE `sys_user`  
  3. (  
  4.     `user_id`         int(10) unsigned NOT NULL AUTO_INCREMENT,  
  5.     `username`        varchar(1024)    NOT NULL unique ,  
  6.     `encode_password` varchar(1024)       NOT NULL,  
  7.     `age`             int(3)           NOT NULL,  
  8.     PRIMARY KEY (`user_id`)  
  9. ) ENGINE = InnoDB  
  10.   DEFAULT CHARSET = utf8mb4;  
  11. insert into  flyway.sys_user values (1,'Felordcn','{noop}12345',18); 

(编辑:湖南网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读