git - Git:如何恢复/撤消大规模合并?
问题描述
首先,我知道 StackOverflow 中已经有大量与合并相关的答案。我只是花了一个小时的大部分时间梳理他们试图弄清楚这一点......
我的问题是我有一个非常古老的分支,分支 A(比如从 2017 年开始)。我想更新它,所以我从 master 合并(它是最新的,大约 2019 年)并推送。这为历史添加了大量的提交。在我需要用分支 B 而不是 master 更新分支 A 之后,有人告诉我......我怎样才能摆脱 master 合并并将分支 A 返回到其原始状态?
也许我应该只使用“git revert X”并吃掉它会留下的可怕历史?
我见过的大多数答案都提到在合并之前检查“最后一次已知的良好”提交,但我不知道提交哈希,并且历史从我的合并中现在已经存在多年的提交。我确实知道我的合并提交的提交哈希 - 我们称之为 X。我的假设是 LKG 提交将是 X^1,我已经用“git log X^1”查看了它。但是,我想在更改分支历史之前确定这是正确的,而且我很难查看围绕 X^1 的提交。
解决方案
如果您想要做的实际上是摆脱所有来自 master 的修订,因为您从未合并过,那么您应该git reset --hard
(提供 A 之前的修订的 id ...检查git reflog
或分支的日志)...那么就像你从未发生过的任何事情一样。
推荐阅读
- firebase - Firebase 获取基于角色的文档
- reactjs - 用于生成布局的 Gatsby 动态路由 URL
- python - 正则表达式查找带或不带 www 的有效 URL,包括点但不包括双点
- python - 为什么在安装 ZS 库 Python 时会出现此错误?错误:命令出错,退出状态为 1:命令:path/python -u -c 'import sys,
- node.js - 致命错误:CALL_AND_RETRY_LAST 分配失败 - JavaScript 堆内存不足构建 Angular 应用程序
- python - 当我把我的 .py 变成一个可执行文件时,它会弄乱程序。(自动 py 到 exe)
- python - 如何在我的 Flask 应用程序中登录到 systemd 日志而不是 syslog?
- android - 如何以编程方式退出应用程序固定?
- javascript - 如何重构两种不同类型的子类的实现,同时保留其方法的功能和命名?
- php - 将对象函数作为回调传递