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

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

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

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


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

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


当前回答

删除最近的提交,而不破坏您所做的工作:

git reset—软HEAD~1

删除最近的提交并删除更改:

git重置--硬HEAD~1

其他回答

如果您使用的是Atlassian SourceTree应用程序,可以使用上下文菜单中的重置选项。

只需删除本地主分支,然后按如下方式重新创建:

git branch -D master
git checkout origin/master -b master
git reset --hard <SHA-Code>

如果您在本地副本上犯了一些错误,希望确保不会被错误地推送到远程分支,这将非常有用。

SHA代码可以通过查看git仪表板的webVersion获取,以获取分支上的最后一次提交。

这样,您可以与分支上的最后一次提交同步。

您可以在成功完成硬重置后执行git pull,以确认syn没有任何新内容,即您可以看到消息。

您的分支机构是最新的来源/<分支机构名称>

gitreset-hard@{u}*删除当前分支上的所有本地更改,包括提交。我很惊讶还没有人发布这篇文章,考虑到你不必查找要恢复到的内容或使用分支。

*也就是说,在@{upstream}-通常是origin/<branchname>处重置为当前分支,但并不总是这样

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

您可以发布:

git reset --hard HEAD~5

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