由于一些糟糕的选择,我的本地Git存储库目前比原始库提前了五次提交,并且状态不佳。我想摆脱所有这些承诺,重新开始。

很明显,删除我的工作目录并重新克隆就可以了,但再次从GitHub下载所有内容似乎太过了,而且没有很好地利用我的时间。

也许git-restore是我需要的,但我不想在源代码之前提交10次(甚至6次),即使它确实将代码本身恢复到正确的状态。我只想假装最后半小时从未发生过。

有一个简单的命令可以做到这一点吗?这似乎是一个明显的用例,但我找不到任何例子。


请注意,这个问题专门针对提交,而不是:

未跟踪的文件未分级更改已分段但未提交的更改


当前回答

查找要还原到的提交的sha1:

za$ git reflog
... snip ...
cf42fa2... HEAD@{0}: commit: fixed misc bugs
~
~
cf42fa2... HEAD@{84}: commit: fixed params for .....
73b9363... HEAD@{85}: commit: Don't symlink to themes on deployment.
547cc1b... HEAD@{86}: commit: Deploy to effectif.com web server.
1dc3298... HEAD@{87}: commit: Updated the theme.
18c3f51... HEAD@{88}: commit: Verify with Google webmaster tools.
26fbb9c... HEAD@{89}: checkout: moving to effectif

然后使用--mixed标志,以便“重置HEAD和索引”:

za$ git reset --mixed cf42fa2

可用标志:

za$ git reset -h

-q, --quiet           be quiet, only report errors
--mixed               reset HEAD and index
--soft                reset only HEAD
--hard                reset HEAD, index and working tree
--merge               reset HEAD, index and working tree
--keep                reset HEAD but keep local changes
--recurse-submodules[=<reset>]
                      control recursive updating of submodules
-p, --patch           select hunks interactively
-N, --intent-to-add

其他回答

简单的解决方案是将本地主分支HEAD与源/主分支HEAT匹配

git reset --hard origin/master

PS:origin/master-是指向主分支的远程指针。您可以用任何分支名称替换master

您可以使用此git命令

git reset --hard origin/<branch_name>

对于那些对Visual Studio解决方案感兴趣的人,以下是演练:

在团队资源管理器窗口中,连接到目标存储库。然后从“分支”中,右键单击感兴趣的分支并选择“查看历史记录”。右键单击历史窗口中的提交,然后选择重置->删除更改(--hard)。

这将丢弃本地提交,并将回购的状态重置为所选提交。也就是说,取消回购后的更改将丢失。

更新

上述程序在VS2019之前运行良好;在VS2022中,有新的Git体验。工作流程类似,但UI有点不同。使用Git菜单中的管理分支,而不是团队资源管理器。现在只需单击左侧的分支,其历史记录将显示在右侧。然后右键单击->重置->删除更改(--hard)

如果您的分支比“origin/XXX”领先5次提交。

您可以发布:

git reset --hard HEAD~5

它应该删除最后5个提交。

对于未被推送的本地提交,还可以使用gitrebase-i删除或压缩提交。