如何轻松撤消git重基?冗长的手动方法是:

签出两个分支的提交父级创建并签出临时分支手工挑选所有提交重置故障的重基分支以指向临时分支

在我目前的情况下,这是可行的,因为我可以很容易地发现两个分支的提交(一个是我的东西,另一个是同事的东西)。然而,我的方法给我的印象是次优且容易出错(假设我刚刚用自己的两个分支重新建立了基础)。

澄清:我所说的是一个重基,在重基过程中,多次提交被重复,而不仅仅是一次。


当前回答

git reset --hard origin/{branchName}

是重置rebase所做的所有本地更改的正确解决方案。

其他回答

git reset --hard origin/{branchName}

是重置rebase所做的所有本地更改的正确解决方案。

对于多次提交,请记住,任何提交都引用导致该提交的所有历史记录。因此,在查尔斯的回答中,将“旧承诺”读为“旧承诺中的最新承诺”。如果您重置为该提交,那么导致该提交的所有历史记录都将重新出现。这应该是你想要的。

最简单的方法是找到分支的头部提交,因为它在reflog中的rebase开始之前。。。

git reflog

并将当前分支重置为它(通常需要注意的是,在使用--hard选项重设种子之前要绝对确定)。

假设ref日志中的旧提交是HEAD@{2}:

git reset --hard HEAD@{2}

在Windows中,您可能需要引用引用:

git reset --hard "HEAD@{2}"

您可以通过执行git-log head@{2}(Windows:git-log“head@{2}”)来检查候选旧标头的历史记录。

如果您没有禁用每个分支的reflog,您应该能够简单地执行gitreflog branchname@{1},因为在重新连接到最终头之前,rebase会分离分支头。我会再次检查这个,尽管我最近没有验证过。

默认情况下,为非裸存储库激活所有reflog:

[core]
    logAllRefUpdates = true

查尔斯的答案有效,但你可能想这样做:

git rebase --abort

重置后进行清理。

否则,您可能会收到消息“Interactive rebase already started”。

按照@Allan和@Zearin的解决方案,我希望我可以简单地发表评论,但我没有足够的声誉,所以我使用了以下命令:

我不得不简单地执行gitrebase-i-art(不使用-i),而不是执行gitrebase-i-art。

同时使用-i和--abort会导致Git显示用法/选项列表。

因此,我以前和现在使用此解决方案的分支状态是:

matbhz@myPc /my/project/environment (branch-123|REBASE-i)
$ git rebase --abort

matbhz@myPc /my/project/environment (branch-123)
$