SVN创建分支与合并分支

2023-11-11

SVN忽略target文件夹

鼠标右键项目 -> TortoiseSVN -> Settings
在这里插入图片描述
1、*号代表所有,*.idea *target 忽略.idea文件夹和target文件夹
2、注意每个过滤的文件中间要留空格

SVN创建分支

1、trunk主干新建maven工程spring-boot-demo项目并commit提交到SVN版本库
在这里插入图片描述
项目结构:
在这里插入图片描述
2、选中需要建立分支的项目spring-boot-demo,右键-->TortoiseSVN-->Branch/tag
在这里插入图片描述
3、To path 选择分支路径
在这里插入图片描述
Copy 完成!
在这里插入图片描述
4、查看远程库分支项目代码
在这里插入图片描述
5、本地branches目录拉取分支代码
在这里插入图片描述

SVN合并分支

合并是合并到本地的working copy,不是直接合并远程版本库,合并到本地工作目录需要自己选择是否提交到版本库。所以合并前需要将项目更新或者提交代码,否则会未提交的代码可能会丢失

1、分支添加查询用户接口代码,提交代码。
在这里插入图片描述
2、将分支代码合并到主干
将分支合并到主干,需要选择主干代码右键Merge,选择对应合并类型处理。
将主干合并到分支,就需要选择对应分支右键Merge,选择对应合并类型处理。

在这里插入图片描述
3、选择合并类型
在这里插入图片描述

  • merge a range of revisions: 就是将分支修改合并到主分支(理解为主干代码)上来,分支可以选择一个或者多个版本,主分支不能选择版本。
  • merge two different trees: 主分支和分支都可以选择版本,合并的时候以选择的分支为主。合并时如果有不同,会将主分支不同的删掉。from 和 to 要选择正确,from是主分支,to是分支。

merge a range of revisions

选好我们的分支版本,即spring-boot-demo1128分支,然后选择哪些版本进行合并,可以是all revisions,全部版本,也可以指定版本。
在这里插入图片描述
指定好版本之后下一步,这里可以选择是否比较空白等选项,然后可以先Test Merge测试下合并,如果觉得没问题那就直接点击"Merge"
在这里插入图片描述
合并完成
在这里插入图片描述
查看主分支代码、idea显示有修改未提交的代码。可以选择是否进行提交到主干代码库中
在这里插入图片描述

merge two different trees

1、分支spring-boot-demo1128新增保存用户方法saveUser1,并commit提交远程库。
在这里插入图片描述
主分支spring-boot-demo新增PersonController类,方法getPerson,并commit提交远程库。
在这里插入图片描述

2、右键主分支代码TortoiseSVN-->Merge,选择merge two different trees方式将分支代码合并到主分支上来,这里记得from是主分支spring-boot-demo项目,to是分支spring-boot-demo1128项目,选择好版本以后进行合并。

From含义:合并的主分支代码
To含义: 需要被合并的分支代码
在这里插入图片描述
3、指定好版本之后下一步,这里可以选择是否比较空白等选项,然后可以先Test Merge测试下合并,如果觉得没问题那就直接点击"Merge"
在这里插入图片描述
合并完成
在这里插入图片描述

4、查看主分支代码。分支的Application类的saveUser1方法同步到了主分支的working copy中。但是主分支的PersonController类被删除了。
在这里插入图片描述
这就是merge two different trees类型的合并方式,分支代码合并上来的时候会把主干上面新增的删掉,所以对这种类型我们合并的时候应该注意,这里from里的版本不应该是主干最新的版本,而应该是当时拉取分支的时候的版本,也可以理解为是分支的第一个版本,然后to是分支的最新版本,这样才会把分支最新的代码合并到working copy里,然后在同步合并将本地working copy合并到主干中。

5、按照上面的思路在试一次。主干选择Revert掉合并的分支代码,回到上一次未合并的版本。
在这里插入图片描述
钩选对应文件
在这里插入图片描述
6、重新走上面的步骤2,选择合并到的主分支代码为提交PersonController文件的上一个版本
在这里插入图片描述

这里选择远程版本2、6会发生代码冲突。原因是: 主分支本地库working中Application文件中已经存在getUser方法和saveUser方法,如果分支合并,等于修改了同一处地方。所以会发生代码冲突。

合并完成

在这里插入图片描述
7、查看主分支代码。发现只有Application类被修改,PersonController类没有被删除。可以选择是否进行提交到主干代码库中
在这里插入图片描述
代码也同步到主线中了,这样就实现了分支向主线合并的功能。

合并分支总结

1、哪个分支合并到哪个分支,就选择哪个分支右键分支代码TortoiseSVN-->Merge,比如A分支合并到B分支,此时B分支就是主分支,选择B分支右键分支代码TortoiseSVN-->Merge
2、使用merge a range of revisions时,URL From为被合并的分支代码。即A分支
3、使用merge two different trees时,From指定为合并的主分支代码,即B分支。To指定为需要被合并的分支代码,即A分支。

主线往分支合并也是同一个道理

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

SVN创建分支与合并分支 的相关文章

随机推荐

  • linux中copy_to_user()和copy_from_user()函数

    由于内核空间与用户空间的内存不能直接互访 因此借助函数 copy from user 完成用户空间到内核空间的复制 函数copy to user 完成内核空间到用户空间的复制 copy from user 和 copy to user 的原
  • 从第一人称的角度去带你了解Shell脚本的编写过程及思路

    前言 最近有朋友拿了两个文本给我 里面全都是IP地址 第一个IP地址是已安装相关服务的主机地址 第二个地址则是某一区域的所有主机IP地址 其中第一个文本有部分内容与第二个文本的内容重复 说明是已经安装了的 而第一个文本除了包含第二个文本的部
  • 单节锂电池充放电及外部供电自动切换的电路--原理介绍

    目录 单节锂电池充放电及外部供电自动切换的电路 原理介绍 1 电源输入与输出 2 虚线左边的电路是充电电路 3 虚线右侧的电路是自动切换电路 4 元器件的选择 5 PCB设计建议 单节锂电池充放电及外部供电自动切换的电路 原理介绍 介绍一种
  • 利用matlab建立一个压缩机的热力学数学模型,给出具体的代码

    我不太懂你在说什么 但是我可以提供一些参考资料 可以帮助你建立压缩机的热力学数学模型 1 MATLAB编程指南 https www mathworks com help matlab programming guide html 2 MAT
  • WSL2 在 Windows10下的 网卡 配置问题

    网络上的大部分解决方案是 在Hyper V 的WSL的虚拟交换机中的连接类型改成外部网络 然后在用户目录 USERPROFILE 下面创建一个配置文件 wslconfig wsl2 networkingMode bridged 桥接模式 v
  • CTFHub-web(cookie注入)

    文章目录 一 解题步骤 二 关于sql中 id 多少 的说明 一 解题步骤 1 题目为cookie注入 我们首先先看一下cookie里的值有没有什么可以帮助我们思考的东西 id 1 很明显存在sql注入 2 我们抓包来一步步的进行注入会更方
  • .Net Core跨域处理

    查看官方文档 https docs microsoft com zh cn aspnet core security cors view aspnetcore 2 2 分两部分处理跨域 ConfigureServices里添加 servic
  • 【华为OD机试】模拟消息队列【2023 B卷

    华为OD机试 真题 点这里 华为OD机试 真题考点分类 点这里 题目描述 让我们来模拟一个消息队列的运作 有一个发布者和若干消费者 发布者会在给定的时刻向消息队列发送消息若此时消息队列有消费者订阅 这个消息会被发送到订阅的消费者中优先级最高
  • awk的数组学习心得

    http bbs chinaunix net thread 2312439 1 2 html 在文本处理的工作中 awk的数组是必不可少的工具 在这里 同样以总结经验和教训的方式和大家分享下我的一些学习心得 如有错误的地方 请大家指正和补充
  • 医学图像语义分割最佳方法的全面比较:UNet和UNet++

    点击上方 AI公园 关注公众号 选择加 星标 或 置顶 作者 Sergey Kolchenko 编译 ronghuaiyang 导读 在不同的任务上对比了UNet和UNet 以及使用不同的预训练编码器的效果 介绍 语义分割是计算机视觉的一个
  • 超好用的数学公式识别软件mathpix!

    在写科研论文或者其他论文 亦或者将word里的公式搬到latex里进行排版 数学公式总是一项非常艰巨的任务 在电脑上输入的速度远远没有手写来得快 既然如此 有没有办法直接识别手写的公式呢 有 就是这个软件 mathpix 怎么使用呢 下载安
  • Linux-RPM软件包管理/dnf管理软件/源码安装教程/使用systemd管理服务

    文章目录 管理软件包 RPM软件包 Linux软件包管理概述 RPM软件包管理 RPM软件包管理的优缺点 使用RPM命令管理软件 安装 查询 升级 卸载 RPM命令常用参数 RPM命令 安装 RPM命令 卸载 RPM命令 升级 RPM 查询
  • jdbc原理与步骤

    jdbc原理 1 加载JDBC驱动 并将其注册到DriverManager 2 建立数据库连接 获取connection对象 3 建立Statement对象或PreparedStatement对象 4 执行SQL语句 5 访问结果集Resu
  • 送本书《Python 之旅》

    在线阅读 下载 在线阅读 https www bookstack cn books explore python 下载 关注公众号马上码回复 pythonzl Python 是一门面向对象 解释型的高级程序设计语言 它的语法非常简洁 优雅
  • 分析游戏《明日方舟》的成功要素

    明日方舟 这个出身并不显赫 玩法也绝非时下主流的游戏一经上线 就在一个月内连续霸榜 在正式上线一个月的时候 顺理成章地登顶App Store畅销榜榜首 简单介绍游戏信息与核心玩法 游戏名称 明日方舟 英文名称 Arknights 制作厂商
  • element-ui el-tree树形控件 默认箭头更改

    这是基础性 那么怎么修改呢 很简单只需要在css中修改 注意 vue中修改需要添加 deep el icon arrow right color 49c0ff el table el table expand icon el icon ar
  • 秒杀多线程第十五篇 多线程十大经典案例之一 双线程读写队列数据

    秒杀多线程第十五篇 多线程十大经典案例之一 双线程读写队列数据 多线程十大经典案例之一双线程读写队列数据 案例描述 MFC对话框中一个按钮的响应函数实现两个功能 显示数据同时处理数据 因此开两个线程 一个线程显示数据 开了一个定时器 响应W
  • jdk 16中改进的ZGC

    内存对象重定位的优化 预留堆空间 heap reserve 是堆空间中特殊的一块小空间 无法用于java线程的常规分配 而当发生gc时需要进行对象重分配时才会使用 此举确保了空的堆区域可用 即使是在java线程角度看堆空间已满 仍可进行对象
  • arch/x86/entry/syscall_64.o:(.rodata+0xa78): undefined reference to `sys_get_pid_info‘

    今天添加系统调用以后 使用make指令编译内核的时候出现了 arch x86 entry syscall 64 o rodata 0xa78 undefined reference to sys myprint 这个错误 错误原因是我使用的
  • SVN创建分支与合并分支

    SVN创建分支与合并分支 SVN忽略target文件夹 SVN创建分支 SVN合并分支 merge a range of revisions merge two different trees 合并分支总结 SVN忽略target文件夹 鼠