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

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

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.lryc.cn/news/517652.html

相关文章:

  • Windows下安装最新版的OpenSSL,并解决OpenSSL不是当前版本的问题,或者安装不正确的问题
  • Django 社团管理系统的设计与实现
  • android compose 串口通信
  • Cursor无限续杯——解决Too many free trials.
  • 网络传输层TCP协议
  • 我的前端面试笔记(React篇)
  • Qt 5.14.2 学习记录 —— 팔 QWidget 常用控件(3)
  • HTTP协议和WebSocket协议
  • 校园网断网自检测重链接
  • LAMP搭建
  • Sentinel-5P遥感数据下载及预处理教程【20250105】
  • 手写@MapperScan
  • 【C++】深入理解迭代器(Iterator)
  • 后端Java开发:第十二天
  • 记录一下Coding一直不能clone
  • LLM加速方法,Adapter Tuning和Prompt Tuning的区别及原理举例
  • 【SVN】版本发布快捷操作
  • GitLab 创建项目、删除项目
  • STM32-笔记37-吸烟室管控系统项目
  • VisionPro软件Image Stitch拼接算法
  • 【从零开始入门unity游戏开发之——unity篇09】unity6基础入门——Unity游戏对象和组件的本质、Unity中的反射机制
  • 【Linux】深入理解文件系统(超详细)
  • MoEs and Transformers 笔记
  • 在Linux中,如何禁用root用户直接SSH登录?
  • 用Python实现简单的任务自动化
  • 为AI聊天工具添加一个知识系统 之26 资源存储库和资源管理器
  • Windows10环境下安装RabbitMq折腾记
  • 对快速由表及里说拜拜/如何正确运用由表及里
  • spring mvc源码学习笔记之八
  • 探秘5网口IIOT网关