有没有办法恢复或撤销git拉,使我的源/回购将回到做git拉之前的旧状态? 我想这样做是因为它合并了一些我不想这样做的文件,但只合并了其他剩余的文件。我想拿回那些文件,可以吗?

编辑:我想撤销git合并澄清。 看到一些答案后,我这样做了

git reflog
bb3139b... HEAD@{0}: pull : Fast forward
01b34fa... HEAD@{1}: clone: from ...name...

现在,我该怎么办?做git重置——难吗?我不想再搞砸了,所以问详细步骤?


当前回答

如果你有gitk(试着运行“gitk—all from your git命令行”),这很简单。只需运行它,选择你想要回滚到的提交(右键单击),并选择“重置主分支到这里”。如果没有未提交的更改,则选择“hard”选项。

其他回答

你可以做git重置——hard ORIG_HEAD

因为“pull”或“merge”在执行这些操作之前将ORIG_HEAD设置为当前状态。

我建议做的第一件事是做一个项目的副本。

你可以签出一个新的分支(git checkout -b NewCopy),这样你就可以有一个副本,然后返回到你签出的分支。

使用实例查看git引用。

git reflog

它将显示您的参考日志和commit_Id{类似e0371eb},您可以使用它们返回到特定的参考点。

运行此命令可回溯到某个点

git reset --hard 7316f34  //replace that with your commit id

我建议打开两个终端,一个用来显示日志,另一个用来运行命令

如果有一个失败的合并,这是最常见的原因,想要撤销一个git拉,运行git reset——merge完全是人们所期望的:保留获取的文件,但撤销的合并,git拉试图合并。然后,你可以决定如何做,而不是git合并有时产生的混乱。它不需要找到确切的提交ID,这在其他答案中很难提到。

它的工作原理 首次使用:git reflog

找到你之前状态的SHA并make(以HEAD@{1}为例)

git reset --hard HEAD@{1}

试着运行

git reset --keep HEAD@{1}