如何在git中回滚到特定的提交?

有人能给我的最好答案是使用git恢复X次,直到我达到所需的提交。

假设我想要恢复到20次提交前的提交,我需要运行20次。

有更简单的方法吗?

我不能使用重置,因为这个存储库是公共的。


当前回答

git read-tree -um @ $commit_to_revert_to

我会做的。它是“git checkout”,但没有更新HEAD。

你可以达到同样的效果

git checkout $commit_to_revert_to
git reset --soft @{1}

如果您喜欢将方便的命令串在一起。

这将使你的工作树和索引处于所需的状态,你可以git提交完成。

其他回答

假设你在做一个项目,过了一天左右。您注意到有一个特性仍然出错。但是你不知道你做了什么改变导致了错误。所以你必须找出以前的工作提交。恢复到特定的提交:

git checkout 8a0fe5191b7dfc6a81833bfb61220d7204e6b0a9 .

好的,这个commit对你有用。不会再有错误了。你指出了问题所在。现在你可以回到最近的提交:

git checkout 792d9294f652d753514dc2033a04d742decb82a5 .

在导致错误之前签出一个特定的文件(在我的例子中,我使用Gemfile.lock):

git checkout 8a0fe5191b7dfc6a81833bfb61220d7204e6b0a9 -- /projects/myproject/Gemfile.lock

这是一种处理在提交中创建的错误的方法,直到以后才会意识到这些错误。

我不确定发生了什么变化,但如果没有分离选项,我无法签出特定的提交。对我有效的完整命令是: Git签出-detach[提交散列]

要从分离状态返回,我必须签出我的本地分支:git checkout master

想要HEAD分离模式?

如果你希望回滚X次到一个带有DETACHED HEAD的特定提交(意味着你不能搞砸任何事情),那么无论如何,使用以下方法:

(将X替换为您希望返回的提交次数)

git checkout HEAD~X

即返回一次提交:

git checkout HEAD~1

第一步:获取提交列表:

git log

你会得到如下所示的列表:

[Comp:Folder User$ git log
commit 54b11d42e12dc6e9f070a8b5095a4492216d5320
Author: author <author@gmail.com>
Date:   Fri Jul 8 23:42:22 2016 +0300

This is last commit message

commit fd6cb176297acca4dbc69d15d6b7f78a2463482f
Author: author <author@gmail.com>
Date:   Fri Jun 24 20:20:24 2016 +0300

This is previous commit message

commit ab0de062136da650ffc27cfb57febac8efb84b8d
Author: author <author@gmail.com>
Date:   Thu Jun 23 00:41:55 2016 +0300

This is previous previous commit message
...

步骤2:复制所需的提交散列并粘贴以供检查:

git checkout fd6cb176297acca4dbc69d15d6b7f78a2463482f

这是所有。

在git中回滚一个特定的提交:

要返回一个旧的git提交:(the ac2ec…是提交名称)

git checkout ac2ece0219689ed86b08c93dfebb0d02c0f1d5b1

命名一个你想要HEAD分离指向的新分支:

git branch get_back_to_past

结帐到分支

git checkout get_back_to_past

现在该分支有了过去的提交项。例如,如果您愿意,您可以将其合并到主数据库。

有关git头部和回滚到旧版本的更多信息:点击这里