我只是删除了错误的分支,我需要用git branch -D branchName进行一些实验更改。

如何恢复分支?


当前回答

如果你使用Jetbrains IDE(Goland, phpstorm等)的GUI删除了一个分支

git窗口(IDE的左下角)->控制台选项卡->现在你可以看到IDE执行命令的日志,并从这个日志中找到分支名称和SHA1

其他回答

首先:备份您的整个目录,包括.git目录。

第二:你可以使用git fsck——lost-found来获取丢失提交的ID。

第三:在丢失的提交上重新设置或合并。

第四:在git中使用-D或——force之前一定要三思:)

您还可以阅读这篇关于如何从此类错误中恢复的优秀讨论。

编辑:顺便说一下,不要运行git gc(或者允许它自己运行——也就是不要运行git fetch或类似的东西),否则你可能会永远失去你的提交。

首先,不要惊慌。你来对地方了。 继续,冠军,我们都会犯错!这就是我们学习的方式! 祝你健康、快乐、成功!

哦,等待答案!我想你已经知道了!

如果不是!这就是答案。

use git reflog
git checkout branch branch_name commitsha

为了进一步说明,在第二个命令中,branch_name是您想要给分支指定的名称。Commitsha是您要检查的sha号码。你可以从git reflog命令中获得。

再次快乐编码!

如果你还没有推送删除,你可以简单地做:

$ git checkout deletedBranchName

如果你刚刚删除了分支,你会在终端中看到如下内容:

Deleted branch branch_name(was e562d13)

其中e562d13是一个唯一的ID(也就是“SHA”或“散列”),使用这个可以恢复已删除的分支。

要恢复分支,使用:

git checkout -b <branch_name> <sha>

例如:

git checkout -b branch_name e562d13 

你可以使用git reflog找到分支最后一次提交的SHA1。从这一点开始,您可以使用

git branch branchName <sha1>

编辑:正如@seagullJS所说,分支-D命令告诉你sha1,所以如果你还没有关闭终端,它变得非常容易。例如,它删除并立即恢复一个名为master2的分支:

user@MY-PC /C/MyRepo (master)
$ git branch -D master2
Deleted branch master2 (was 130d7ba).    <-- This is the SHA1 we need to restore it!

user@MY-PC /C/MyRepo (master)
$ git branch master2 130d7ba