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

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

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

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


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

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


当前回答

要查看/获取提交的SHA-1 id,您也需要返回

gitk --all

回滚到该提交

git reset --hard sha1_id

!笔记在提交之后进行的所有提交都将被删除(以及对项目的所有修改)。因此,首先最好将项目克隆到另一个分支或复制到另一目录。

其他回答

您可以考虑使用带有drop命令的交互式rebase

比如说最后三次犯罪。。。

git rebase -i HEAD~3

交换拾取命令

pick <hash1> Commit message 1
pick <hash2> Commit message 2
pick <hash3> Commit message 3

用于放置命令

drop <hash1> Commit message 1
drop <hash2> Commit message 2
drop <hash3> Commit message 3

TL;博士

在你的树枝上

git reset--hard HEAD^将丢弃最后一次本地提交

git reset--hard HEAD~n将丢弃最后n个本地提交

对于所有未标记的更改,git checkout--。

对于特定文件git checkout--路径/to/file/to/revert

我有一种情况,我想删除一个未被推送的提交,但该提交在另一个提交之前。为此,我使用了以下命令

git rebase-i HEAD~2->它将对最后两次提交进行重新基化

我使用“drop”作为我想要删除的提交签名。

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

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