问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

如何安装git以及如何利用git管理文件版本

发布网友 发布时间:2022-04-23 01:14

我来回答

2个回答

懂视网 时间:2022-04-11 15:42

Flyway 将 SQL 文件分为 Versioned 、Repeatable 和 Undo 三种:

  • Versioned 用于版本升级, 每个版本有唯一的版本号并只能执行一次.

  • Repeatable 可重复执行, 当 Flyway检测到 Repeatable 类型的 SQL 脚本的 checksum 有变动, Flyway 就会重新应用该脚本. 它并不用于版本更新, 这类的 migration 总是在 Versioned 执行之后才被执行。

  • Undo 用于撤销具有相同版本的版本化迁移带来的影响。但是该回滚过于粗暴,过于机械化,一般不推荐使用。一般建议使用 Versioned 模式来解决。
  • 这三种的命名规则如下图:

    技术图片

  • Prefix 可配置,前缀标识,默认值 V 表示 Versioned, R 表示 Repeatable, U 表示 Undo
  • Version 标识版本号, 由一个或多个数字构成, 数字之间的分隔符可用点 . 或下划线 _
  • Separator 可配置, 用于分隔版本标识与描述信息, 默认为两个下划线 __
  • Description 描述信息, 文字之间可以用下划线 _ 或空格 分隔
  • Suffix 可配置, 后续标识, 默认为 `.sql```
  • 4. Spring Boot 集成 Flyway

    Spring Boot 提供了对 Flyway 的自动配置 。使我们可以开箱即用 Flyway 进行数据库版本控制。

    4.1 Flyway 依赖

    你只需要引入依赖:

     <!-- 无需版本号 -->
     <dependency>
     <groupId>org.flywaydb</groupId>
     <artifactId>flyway-core</artifactId>
     </dependency>

    当然你要集成你的相关数据库环境。这里我们采用 H2 数据库来演示,其它数据库同理只不过方言不同。不熟悉 H2 数据库的可参阅我的专题文章 Spring Boot 2 实战:H2数据库集成以及使用 。

    4.2 Flyway 配置

    为了直观的讲解配置,首先在 Spring Boot 配置文件 application.yml 我们配置 H2 数据库为:

     spring:
     datasource:
     # h2 驱动
     driver-class-name: org.h2.Driver
     # h2 数据库 持久化到磁盘D:/h2 库名: flyway mysql模式
     url: jdbc:h2:file:D:/h2/flyway;MODE=MySQL;DATABASE_TO_LOWER=TRUE
     h2:
     # 开启console 访问 默认false
     console:
     enabled: true
     settings:
      # 开启h2 console 跟踪 方便调试 默认 false
      trace: true
      # 允许console 远程访问 默认false
      web-allow-others: true
     # h2 访问路径上下文
     path: /h2-console

    对应Flyway的配置为:

    # flyway 配置
    spring:
     flyway:
     # 启用或禁用 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: false
     # 需要 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

    请务必仔细阅读 Flyway 相关配置的说明。

    4.3 编写 SQL 初始化脚本

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

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

    启动 Spring Boot 应用 。打开 H2 数据库控制台 http://localhost:8080/h2-console ,在 JDBC URL 一栏粘贴 jdbc:h2:file:D:/h2/flyway;MODE=MySQL;DATABASE_TO_LOWER=TRUE 并点击 Connect 按钮会进入以下界面:

    技术图片

    这里 -1 是因为我们缺省了 Flyway 需要的 flyway_schema_history 表 。0 是因为 H2 数据库自动初始化了 Schema flyway ,其它数据库可能需要你手动来建立。

    4.4 编写 SQL 变更脚本

    我们编写一个 V1.0.0__Delete_sysuser_felordcn.sql 来删除 V1.0.1__Add_table_user.sql 中初始化的用户。你会发现启动报错了,因为我们开启了校验,所以对于逻辑错误的版本会抛出异常。我们将版本号更改为 V1.0.2__Delete_sysuser_felordcn.sql 再次启动。通过 H2 数据库控制台我们会发现多了一条变更记录:

    技术图片

    同时 sys_user 表的数据也没有了,符合预期。

    5. Flyway 最佳实践

    通过上面的介绍相信你很快就会使用 Flyway 进行数据库版本控制了。这里总结了一些在实际开发中的使用经验:

    1. 生产务必禁 spring.flyway.cleanDisabled=false
    2. 尽量避免使用 Undo 模式。
    3. 开发版本号尽量根据团队来进行多层次的命名避免混乱。比如 V1.0.1__ProjectName_{Feature|fix}_Developer_Description.sql ,这种命名同时也可以获取更多脚本的开发者和相关功能的信息。
    4. spring.flyway.outOfOrder 取值 生产上使用 false,开发中使用 true
    5. 多个系统公用一个 数据库 schema 时配置spring.flyway.table 为不同的系统设置不同的 metadata 表名而不使用缺省值 flyway_schema_history

    6. 总结

    今天我们对 Flyway 数据库版本迁移管理工具进行了介绍并将之与 Spring Boot 相结合。这将大大规范我们的数据库管理,提高生产效率。同时也分享了一些相当有用的生产实践经验。

    快速学会像Git一样管理数据库业务版本变更

    标签:内容   技术   模式   har   version   依次   脚本   下载   启动   

    热心网友 时间:2022-04-11 12:50

    目前最火的版本控制软件就是Git了吧?你要是还用SVN或者CVS什么的都不好意思在圈里打招呼!前天我就遇到这种情况了,QQ上和老同学聊起自己用SVN来管理程序版本,好麻烦,当场就惨遭鄙视---“你还用SVN啊?你Out了!我们都用Git了!”好吧为了不被人鄙视,也为了可以鄙视别人,我终于也开始学Git了!
    用了几天之后的感觉就是,确实好用啊!难道大家都来追捧!linus继linux之后又造福了人类一把!就是这个东西因为模式和之前的版本控制软件略有不同,所以入门上稍许有点难度,好吧不废话了,讲讲自己的心得体会吧!
    首先不得不讲一下,需要分清git和github这是两个不同的东西,类似于linux和redhat,前者是开源的项目,后者则是利用这个开源的项目提供服务的服务商。github是一个使用git来托管代码的网站,有两种托管方式,一种是公开的,任何人都可以下载和上传代码,另一种是私人的只有建立者制定的人才可以下载或上传代码,私人的只有交钱才能用。
    声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
    养胃的药最好的是什么啊 婴儿积食发烧不愿吃药怎么办 板门穴位在哪个部位 手机设置放偷看的方法? 凝结水回收器生产厂家? 个人账户养老金预测公式:现有5万元,缴费20年,能领多少钱? 临沂比较有名的男装品牌 呼伦贝尔市悦动网络科技有限公司怎么样? 呼伦贝尔中汇实业有限公司怎么样? 呼伦贝尔油玉不绝电子商务有限公司怎么样? 求美国偶像里的一首歌 人的血液,流多少后,会晕倒?流多少后,会去世? I wanna take you away Let&#39;s escape into the music, DJ let it play I just can&#39;t refuse it 休克的过程是什么样的? 求这首歌叫什么名 人类失血百分之多少会重度休克 No Place To Run (Live In Hammersmith) 歌词 休克常见类型有哪些? 麻烦找一篇英语短文,第一句是—— 如何判断休克程度 什么时候用escape() 失血性休克怎么办? 各位大虾,帮忙把下面一段文字用英语翻译过来吧! 休克的分度? Escape°是什麽意思 逃避英语短语是什么? escape into 有没有合理的解释? 女人挎着我的胳膊又赶紧收回去是什么意思 女生说:我想挎你裤子。怎么回复? 上海建行公积金贷款网点复审要多少个工作日? 人体失血达到什么程度会造成休克或死亡 如何使用escape?造句。 失血性休克应如何处理 insert into 中使用escape 休克的临床表现 escape什么意思啊 escape与avoid的区别 英语好的进来下 微信如果拉黑了对方,对方还会看到我的朋友圈吗 flee与escape有什么区别 “flee”与“escape”有什么区别? oracle中escape逃逸的是什么附后 “澹”字的读音是什么? 三点水加敢是什么字? 三点水旁一个勇敢的敢字,念什么?什么意思? 漾的组词有哪些 澹洲到昌江石碌镇有多远 人基因组DNA澹琍CR时条件怎么设置 翡翠质量58.44g是什么意思 澹 还可组哪些词 澹云未雨怎么获取 天涯明月刀ol