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

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

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

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


运行git pull执行以下任务,顺序如下:

git fetch git 合并

合并步骤将在配置中合并已设置的分支。您想撤消合并步骤,但可能不撤消取回(没有多大意义,也不应该是必要的)。

要撤消合并,使用git reset—很难将本地存储库重置到以前的状态;使用git-reflog找到之前状态的SHA-1,然后重置到它。

警告

本节中列出的命令删除所有未提交的更改,可能会导致工作丢失:

git reset --hard

或者,重置到一个特定的时间点,例如:

git reset --hard master@{"10 minutes ago"}

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


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

git reset --hard a0d3fe6

a0d3fe6是怎么找到的

git reflog

看看你想要撤销的点。


一个更现代的撤销合并的方法是:

git merge --abort

还有一种稍显古老的方式:

git reset --merge

在前面的回答中描述的老派方法(警告:将丢弃所有的本地更改):

git reset --hard

但实际上,值得注意的是,git merge——abort只相当于git reset——merge,前提是存在MERGE_HEAD。这可以在git帮助合并命令中读取。

git merge --abort is equivalent to git reset --merge when MERGE_HEAD is present.

失败的合并后,如果没有MERGE_HEAD,失败的合并可以用git reset -merge来撤销,但不一定要用git merge -abort来撤销,所以它们不仅是同一件事情的旧语法和新语法。这就是为什么我发现git reset -merge在日常工作中更有用。


你可以做git重置——hard ORIG_HEAD

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


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

git重置-硬$COMMIT

.

奖金:

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

快拉,变基

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

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

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


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

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

git reset --hard HEAD@{1}

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


这是恢复拉取更改的最简单方法。

** Warning **

请备份您更改的文件,因为它将删除新创建的文件和文件夹。

git reset --hard 9573e3e0

其中9573e3e0是你的{提交id}


Git拉做以下操作。

i. 去取 二、Git 合并

要撤销拉做任何操作:

I. git重置-硬-它恢复所有本地更改也 或 2Git重置—硬master@{5.days. exe。Ago}(比如10.minutes.ago, 1.小时。前,1.天。)来进行局部更改。 或 3Git重置——硬提交

改进:

下次使用git pull -rebase而不是git pull..它的同步服务器更改(获取&合并)。


试着运行

git reset --keep HEAD@{1}

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

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

使用实例查看git引用。

git reflog

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

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

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

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


要将最后的合并恢复到自定义分支,最简单的方法是:

git reset --hard custom-branch@{1}

主分支示例:

git reset --hard main@{1}

这样做取消你的合并操作:git merge——abort。


查看您执行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之上的提交。在此之后,您将获得之前的更改,就像这样简单。


git reflog 这将生成一个如下所示的列表:

2cae310 (HEAD -> ArunJan, origin/ArunJan) HEAD@{0}: checkout:从a590c01f5c2b83adcb36049f3fd590a3244fa745移动到ArunJan a590c01 HEAD@{1}: checkout:从ArunJan移动到a590c01 2cae310 (HEAD -> ArunJan, origin/ArunJan) HEAD@{2}:重置:移动到HEAD 2cae310 (HEAD -> ArunJan, origin/ArunJan) HEAD@{3}:结帐:从4a41a0fa05b98b274f1477991c6a25313f38b1b2移动到ArunJan 4a41a0f HEAD@{4}:结帐:从ArunJan移动到4a41a0fa05b98b274f1477991c6a25313f38b1b2 2cae310 (HEAD -> ArunJan, origin/ArunJan) HEAD@{5}: reset:移动到2cae31078cdf1c8abac9068330b2ccdd3fc424e3 f830534 HEAD@{6}: pull origin ArunJan:由'ort'策略合并。 a590c01 HEAD@{7}:提交:项目创建任务 4a41a0f HEAD@{8}:提交:创建新项目 b6cb3c5 HEAD@{9}: checkout:从b6cb3c5e82aea4c64ab2a1f0c37e53695d21f194移动到ArunJan b6cb3c5 HEAD@{10}: checkout:从dev-server移动到b6cb3c5e82aea4c64ab2a1f0c37e53695d21f194 5eeaf3c (dev-server) HEAD@{11}: revert:恢复“项目创建并复制URL”

选择要恢复到的版本。例如,如果我想恢复到“项目创建任务”,我会选择ID b0168ee。接下来,运行以下命令将存储库恢复到该版本:

Git复位——硬a590c01


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

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