在Git中恢复由SHA哈希提交?

这个问题在这里已经有了答案:

  • 如何将Git存储库恢复到以前的提交? 38个答案

  • 如果您想在当前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"
    

    git-revert做的是创建一个提交,该提交解除了给定提交中所做的更改,创建了一个提交,该提交与给定提交相反(相反)。 因此

    git revert <SHA-1>
    

    应该并且确实有效。

    如果你想倒回到指定的提交,你可以这样做,因为这部分历史还没有发布,你需要使用git-reset,而不是git-revert:

    git reset --hard <SHA-1>
    

    (请注意--hard会让你在工作目录中丢失任何未提交的更改)。

    补充笔记

    顺便说一句,也许这并不明显,但在任何文档说<commit><commit-ish> (或<object> )的地方,都可以放置提交的SHA-1标识符(完整或缩短)。


    它恢复所述提交,即添加与其相反的提交。 如果您想签出较早版本,请执行以下操作:

    git checkout 56e05fced214c44a37759efa2dfc25a65d8ae98d
    
    链接地址: http://www.djcxy.com/p/405.html

    上一篇: Revert to a commit by a SHA hash in Git?

    下一篇: How to move HEAD back to a previous location? (Detached head)