我不清楚如何git revert工作.例如,我想在头部后面恢复提交六次提交,恢复中间提交之间的所有更改.
说它的SHA哈希是56e05fced214c44a37759efa2dfc25a65d8ae98d.那我为什么不能做以下事情:
git revert 56e05fced214c44a37759efa2dfc25a65d8ae98d
Run Code Online (Sandbox Code Playgroud)
CB *_*ley 1103
如果要在当前HEAD上提交具有不同提交的确切状态,撤消所有中间提交,则可以使用reset创建索引的正确状态来进行提交.
# Reset the index and working tree to the desired tree
# Ensure you have no uncommitted changes that you want to keep
git reset --hard 56e05fced
# Move the branch pointer back to the previous HEAD
git reset --soft HEAD@{1}
git commit -m "Revert to 56e05fced"
Run Code Online (Sandbox Code Playgroud)
Jak*_*ski 132
什么混帐复归确实是一个指定的提交创建一个承诺,撤消在给定提交所做的更改,创建提交其反向(当然,倒数).因此
git revert <SHA-1>
Run Code Online (Sandbox Code Playgroud)
应该而且确实有效.
如果你想回退到指定的提交,并且你可以这样做,因为这段历史尚未发布,你需要使用git-reset,而不是git-revert:
git reset --hard <SHA-1>
Run Code Online (Sandbox Code Playgroud)
(注意,--hard这将使您丢失工作目录中的任何未提交的更改).
顺便说一句,也许它并不明显,但在文档说<commit>或<commit-ish>(或<object>)的任何地方,你都可以提交一个SHA-1标识符(完整或缩短).
Mic*_*ker 87
它恢复了所述提交,即添加与其相反的提交.如果要签出早期版本,请执行以下操作:
git checkout 56e05fced214c44a37759efa2dfc25a65d8ae98d
Run Code Online (Sandbox Code Playgroud)
小智 64
回滚到特定提交的最佳方法是:
git reset --hard <commit-id>
Run Code Online (Sandbox Code Playgroud)
然后:
git push <reponame> -f
Run Code Online (Sandbox Code Playgroud)
Flu*_*dan 58
如果您的更改已经被推到一个公共的,共享的远程,并要恢复之间的所有提交HEAD和<sha-id>,那么你可以通过一个承诺范围内git revert,
git revert 56e05f..HEAD
Run Code Online (Sandbox Code Playgroud)
它将恢复56e05f和之间的所有提交HEAD(不包括范围的起点56e05f).
Jac*_*Dam 21
更新:
这个答案比我的回答简单:如何将Git存储库恢复到之前的提交?
原始答案
# Create a backup of master branch
git branch backup_master
# Point master to '56e05fce' and
# make working directory the same with '56e05fce'
git reset --hard 56e05fce
# Point master back to 'backup_master' and
# leave working directory the same with '56e05fce'.
git reset --soft backup_master
# Now working directory is the same '56e05fce' and
# master points to the original revision. Then we create a commit.
git commit -a -m "Revert to 56e05fce"
# Delete unused branch
git branch -d backup_master
Run Code Online (Sandbox Code Playgroud)
这两个指令git reset --hard和git reset --soft亦幻这里.第一个更改工作目录,但它也改变了头.我们通过第二个修复头部.
小智 6
这样就更容易理解了:
git checkout 56e05fced -- .
git add .
git commit -m 'Revert to 56e05fced'
Run Code Online (Sandbox Code Playgroud)
并证明它有效:
git diff 56e05fced
Run Code Online (Sandbox Code Playgroud)