我“不小心”向GitHub推送了一个提交。
是否可以删除此提交?
我想恢复提交之前的GitHub存储库。
我“不小心”向GitHub推送了一个提交。
是否可以删除此提交?
我想恢复提交之前的GitHub存储库。
当前回答
首先将本地更改保存在一旁的某个位置(备份)
您可以浏览最近的提交,然后单击“复制完整SHA”按钮将其发送到剪贴板。
如果您的最后一个提交哈希是,那么让我们说g0834hg304gh3084gh(例如)
您必须运行:
git推送原点+g0834hg304gh3084gh:主
使用您先前复制的哈希,使其成为“HEAD”版本。
添加所需的本地更改。完成;)
其他回答
首先将本地更改保存在一旁的某个位置(备份)
您可以浏览最近的提交,然后单击“复制完整SHA”按钮将其发送到剪贴板。
如果您的最后一个提交哈希是,那么让我们说g0834hg304gh3084gh(例如)
您必须运行:
git推送原点+g0834hg304gh3084gh:主
使用您先前复制的哈希,使其成为“HEAD”版本。
添加所需的本地更改。完成;)
重写历史不是很好。若我们使用git-restore<commit_id>,它将创建所述提交id的干净反向提交。
这样,历史就不会被改写了,相反,每个人都知道,历史已经发生了逆转。
git日志找到要还原的提交git推送原点+7f6d03:主而7f6d03是错误推送提交之前的提交。+用于用力推
就这样。
这里有一个很好的指南,可以轻松简单地解决您的问题!
要保留分支和合并结构,在执行重基时使用--preserve merges选项非常重要:
git rebase --preserve-merges -i HEAD^^
添加/删除文件以获得所需的内容:
git rm classdir
git add sourcedir
然后修改承诺:
git commit --amend
之前的错误提交将被编辑以反映新的索引状态-换句话说,这就像您一开始就没有犯过错误一样
请注意,只有当您还没有按下时,才应该执行此操作。如果您已经推送,那么您只需正常提交修复。