首页 > 解决方案 > Git:如何恢复/撤消大规模合并?

问题描述

首先,我知道 StackOverflow 中已经有大量与合并相关的答案。我只是花了一个小时的大部分时间梳理他们试图弄清楚这一点......

我的问题是我有一个非常古老的分支,分支 A(比如从 2​​017 年开始)。我想更新它,所以我从 master 合并(它是最新的,大约 2019 年)并推送。这为历史添加了大量的提交。在我需要用分支 B 而不是 master 更新分支 A 之后,有人告诉我......我怎样才能摆脱 master 合并并将分支 A 返回到其原始状态?

也许我应该只使用“git revert X”并吃掉它会留下的可怕历史?

我见过的大多数答案都提到在合并之前检查“最后一次已知的良好”提交,但我不知道提交哈希,并且历史从我的合并中现在已经存在多年的提交。我确实知道我的合并提交的提交哈希 - 我们称之为 X。我的假设是 LKG 提交将是 X^1,我已经用“git log X^1”查看了它。但是,我想在更改分支历史之前确定这是正确的,而且我很难查看围绕 X^1 的提交。

标签: git

解决方案


如果您想要做的实际上是摆脱所有来自 master 的修订,因为您从未合并过,那么您应该git reset --hard(提供 A 之前的修订的 id ...检查git reflog或分支的日志)...那么就像你从未发生过的任何事情一样。


推荐阅读