我不清楚git如何恢复工作。例如,我想在头之后提交6次,在中间提交的中间恢复所有更改。
假设其SHA哈希值为56e05fced214c44a37759efa2dfc25a65d8ae98d。那我为什么不能这样做
git revert 56e05fced214c44a37759efa2dfc25a65d8ae98d
我不清楚git如何恢复工作。例如,我想在头之后提交6次,在中间提交的中间恢复所有更改。
假设其SHA哈希值为56e05fced214c44a37759efa2dfc25a65d8ae98d。那我为什么不能这样做
git revert 56e05fced214c44a37759efa2dfc25a65d8ae98d
当前回答
回滚到特定提交的最好方法是:
git reset --hard <commit-id>
然后:
git push <reponame> -f
其他回答
应该像这样简单:
git reset --hard 56e05f
它会让你回到那个特定的时间点。
它将还原所述的提交,即添加与之相反的提交。如果你想签出以前的版本,你可以:
git checkout 56e05fced214c44a37759efa2dfc25a65d8ae98d
git-revert所做的是创建一个提交,撤销在给定提交中所做的更改,创建一个与给定提交相反(好吧,是互惠)的提交。因此
git revert <SHA-1>
应该做功,也确实做功。
如果你想回退到指定的提交,你可以这样做,因为这部分历史还没有发布,你需要使用git-reset,而不是git-revert:
git reset --hard <SHA-1>
(注意——hard会使您丢失工作目录中任何未提交的更改)。
额外的笔记
顺便说一下,可能不太明显,但是在文档中说<commit>或<commit-ish>(或<object>)的任何地方,您都可以放置一个提交的SHA-1标识符(完整或缩短)。
这可能有用:
git checkout 56e05f
echo ref: refs/heads/master > .git/HEAD
git commit
这比较容易理解:
git checkout 56e05fced -- .
git add .
git commit -m 'Revert to 56e05fced'
为了证明它有效:
git diff 56e05fced