当前位置: 首页 > article >正文

如何将某两个提交去掉父提交的合并

q:
在一个两个月前的分支,我想保持纯净,但是需要把另一个变化很大的分支只将某两个提交的变更同步过来,基于idea的git操作该怎么做

a:
其实很多人会一下想到cherry pick,这个确实方便,但是会将父提交连带合并,如果不需要并且变动很多那就不行了。解决方法如下:

使用 git diff 提取补丁并应用
如果你只希望同步特定提交的变更,而不包括父提交的内容,你可以采用 生成补丁并应用 的方法。这个方法可以让你精确控制同步的变更内容。

步骤 1:获取提交的差异(生成补丁)
打开 Git Log,找到你需要同步的提交。

右键点击该提交并选择 Show Diff,查看该提交的差异内容。

使用 Git 命令生成该提交的补丁:

打开命令行终端(你可以直接在 IDEA 中打开 Terminal)。
运行以下命令,导出该提交的差异为补丁文件(commit-hash 替换为实际的提交哈希):
git diff ^ > patch.diff

这里: 是你想同步的提交的哈希值。
^ 表示该提交的父提交,^ 是获取从父提交到当前提交之间的差异。
这会生成一个补丁文件 patch.diff,它包含了该提交的变更内容。

步骤 2:应用补丁到目标分支
切换到你希望同步变更的目标分支(例如两个月前的分支)。

将生成的补丁应用到目标分支上:

bash
复制代码
git apply patch.diff
这会将该提交的变更应用到当前分支,但不会引入父提交的任何内容。

步骤 3:解决冲突并提交
如果应用补丁时出现冲突,Git 会标记冲突的文件,你需要手动解决冲突。
解决冲突后,使用 git add 标记已解决的文件,然后使用 git commit 提交变更。
步骤 4:推送变更
如果你需要将变更推送到远程仓库,使用 git push 将变更推送到远程。
使用 IntelliJ IDEA 完成
你可以通过 IDEA 的内置终端来执行上述命令:

在 IDEA 中打开 Terminal(终端),使用上述的 git diff 和 git apply 命令来生成并应用补丁。
如果你更倾向于使用 IDEA 的界面,生成补丁后可以手动将其内容复制到修改的文件中,或者通过 IDEA 的合并工具解决冲突。

总结

使用 git diff 和 git apply 的方法,能让你更加精确地控制哪些变更被同步到目标分支,而不会引入不必要的父提交内容。这种方法比直接使用 cherry-pick 更适合只需要同步部分提交的场景。


http://www.kler.cn/a/473410.html

相关文章:

  • Rust 中调用 Drop 的时机
  • C#语言的网络编程
  • 腾讯云AI代码助手编程挑战赛-图片转换工具
  • 海陵HLK-TX510人脸识别模块 stm32使用
  • OpenCV 4.5至4.10版本更新概述
  • STM32-笔记35-DMA(直接存储器访问)
  • YOLOv10改进,YOLOv10改进主干网络为StarNet,CVPR2024,助力模型涨点
  • undolog,redolog,binlog分别是做什么的?
  • VSCODE使用Echarts组件库(不是vue)
  • LeetCode100之组合总和(39)--Java
  • 【已解决】如何让容器内的应用程序使用代理?
  • 怎么分析网页游戏中的数据 官方API 数据挖掘 第三方工具Overwolf、LoLalytics
  • Echarts的认识和基本用法
  • 【Rust自学】11.3. 自定义错误信息
  • 网络安全图谱以及溯源算法
  • Go中的context 包使用详解
  • 图像处理|膨胀操作
  • Windows系统安装Docker Desktop
  • 【踩坑】SparkSQL union/unionAll 函数的去重问题
  • JavaScript动态渲染页面爬取之Selenium
  • Elasticsearch:在 HNSW 中提前终止以实现更快的近似 KNN 搜索
  • 实习总结(经历篇)
  • 聚类系列 (二)——HDBSCAN算法详解
  • GO:sync.Map
  • springboot远程链接spark
  • 力扣 34. 在排序数组中查找元素的第一个和最后一个位置