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

时间:2009-12-12 23:34:40

标签: git

我不清楚git revert的工作原理。例如,我想在头部后面恢复提交六次提交,恢复中间提交之间的所有更改。

说它的SHA哈希是56e05fced214c44a37759efa2dfc25a65d8ae98d。那为什么我不能做一些像:

git revert 56e05fced214c44a37759efa2dfc25a65d8ae98d

9 个答案:

答案 0 :(得分:1061)

如果要在当前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"

答案 1 :(得分:128)

git-revert所做的是创建一个提交,它撤消在给定提交中所做的更改,创建一个提交,它是给定提交的反向(好,相互)。因此

git revert <SHA-1>

应该而且确实有用。

如果您想回退到指定的提交,并且您可以执行此操作,因为此部分历史记录尚未发布,您需要使用git-reset,而不是git-revert:

git reset --hard <SHA-1>

(请注意,--hard会使您丢失工作目录中的任何未提交的更改。

附加说明

顺便说一句,也许这不是显而易见的,但在文档说<commit><commit-ish>(或<object>)的任何地方,您都可以添加SHA-1标识符(完整或缩短了提交。

答案 2 :(得分:84)

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

git checkout 56e05fced214c44a37759efa2dfc25a65d8ae98d

答案 3 :(得分:60)

回滚到特定提交的最佳方法是:

git reset --hard <commit-id>

然后:

git push <reponame> -f

答案 4 :(得分:57)

如果您的更改已被推送到公共,共享远程,并且您想要还原HEAD<sha-id>之间的所有提交,那么您可以传递提交范围为git revert

git revert 56e05f..HEAD

它将还原56e05fHEAD之间的所有提交(不包括范围的起点56e05f)。

答案 5 :(得分:18)

<强>更新

这个答案比我的答案简单:How to revert Git repository to a previous commit?

原始回答

# 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

这两个命令git reset --hardgit reset --soft很神奇。第一个更改工作目录,但它也改变了头。我们通过第二个修复头部。

答案 6 :(得分:3)

这更容易理解:

git checkout 56e05fced -- .
git add .
git commit -m 'Revert to 56e05fced'

并证明它有效:

git diff 56e05fced

答案 7 :(得分:1)

应该如此简单:

git reset --hard 56e05f

那会让你回到那个特定的时间点。

答案 8 :(得分:-2)

这可能有效:

git checkout 56e05f
echo ref: refs/heads/master > .git/HEAD
git commit