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

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

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

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


当前回答

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

其他回答

如果你刚刚在本地拉了一个分支,想要从本地工作区中删除由'git pull'或'git merge'命令引起的更改,那么只需做一个git重置——很难

此命令将从本地工作区中删除所有未提交的更改,并且无法撤消。所以一定要备份你尚未提交的重要工作。

查看您执行git pull命令的当前分支中的日志

git log

示例输出如下所示

commit xxxxxxxxxxxxxxxxxxxxxxxxxxxxxa3dd0
Author: user <user@gmail.com>
Date:   Tue Nov 23 20:19:58 2021 +0530

    latest changes

commit xxxxxxxxxxxxxxxxxxxxxxxxxxxxxd697b
Author: user <user@gmail.com>
Date:   Tue Nov 23 17:45:44 2021 +0530

    latest changes includes account details api

commit xxxxxxxxxxxxxxxxxxxxxxxxxxxxxc0e6fa
Author: user <user@gmail.com>
Date:   Tue Nov 23 17:02:39 2021 +0530

    latest changes

复制您想要的最后一个提交id。例如,如果你的最后一个提交id是xxxxxxxxxxxxxxxxxxxxxxxxxc0e6fa(假设这个提交id是你执行git pull之前的最后一个提交id),并且在这个提交id以上的两次提交是在你的git pull命令之后进行的,那么使用这个提交id来获得之前的更改

git reset --hard xxxxxxxxxxxxxxxxxxxxxxxxxxxxxc0e6fa

这样做将删除该提交id之上的提交。在此之后,您将获得之前的更改,就像这样简单。

假设$COMMIT是执行git pull之前的最后一个提交id。 你要做的就是解除最后一拉

git重置-硬$COMMIT

.

奖金:

说到拉力,我想分享一个有趣的技巧,

快拉,变基

上面这个命令是我git生涯中最有用的命令,它节省了很多时间。

在将你的新提交推到服务器之前,尝试这个命令,它会自动同步最新的服务器更改(使用fetch + merge),并将你的提交放在git日志的顶部。不需要担心手动拉/合并。

详情见:http://gitolite.com/git-pull--rebase

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

与jkp的答案相同,但下面是完整的命令:

git reset --hard a0d3fe6

a0d3fe6是怎么找到的

git reflog

看看你想要撤销的点。