如何从分支历史记录中删除提交?我应该使用git reset-hard HEAD吗?
当前回答
要在本地分支中删除,请使用
git reset --hard HEAD~1
要在远程分支中删除,请使用
git push origin HEAD --force
其他回答
我已经推了。需要远程返回一些提交。尝试了许多变化,但只有Justin via git bush的这句话对我来说很好:
git reset --hard $GIT_COMMIT_HASH_HERE
git push origin HEAD --force
错误:
我git rebase-I--root'ed我的分支,无知地认为我可以重新编写与主提交不同的第一个提交(GitHub for Windows默认视图是与主提交的比较,隐藏了它的全部)。
我留着硅谷的胡子,而900多个会员加入了Sublime。退出时,没有任何变化,我给电池充电,然后开始刮胡子,因为所有900多个人的提交都是无意识地重新启动的-将他们的提交时间重置为现在。
为了击败Git并保持原始时间,我删除了本地存储库并从远程重新克隆。
现在,它重新添加了一个最新的不需要的承诺,我希望删除,所以继续这样做。
用尽所有选项:
我不希望git-restore——它会创建一个额外的提交,让git占据上风。
git reset-hard HEAD什么都没做,在检查了reflog之后,最后一个也是唯一一个HEAD是克隆-git获胜。
为了获得最新的SHA,我查看了github.com上的远程存储库-小赢。
在认为git-reset--hard<SHA>有效后,我将另一个分支更新为master和1…2…poof!提交回来了-Git赢了。
正在检查返回到master,是时候尝试git-rebase-i<SHA>了,然后删除该行。。。没用,很遗憾地说。“如果您删除此处的一行,承诺将丢失”。啊。。。在2.8.3发行说明中,对新功能troll n00b进行了粉饰。
解决方案:
git-rebase-i<SHA>然后d,drop=删除提交。
为了验证,我检查了另一个分支,瞧,没有隐藏的承诺从主节点获取/拉取。
https://twitter.com/holman/status/706006896273063936
祝你今天愉快。
假设您尚未推送到远程存储库,则可以重新克隆存储库。这是我几次选择的方法。
这里我只发布了一条清晰的管道
步骤1:使用gitlog获取提交ID。
git log
步骤2:使用git reset返回到以前的版本:
git reset --hard <your commit id>
要在本地分支中删除,请使用
git reset --hard HEAD~1
要在远程分支中删除,请使用
git push origin HEAD --force
推荐文章
- Visual Studio Code: .git文件夹/文件隐藏
- “node_modules”文件夹应该包含在git存储库中吗
- 为什么git-rebase给了我合并冲突,而我所做的只是压缩提交?
- 当我试图推到原点时,为什么Git告诉我“没有这样的远程‘原点’”?
- 如何从远程分支中挑选?
- 如何查看一个分支中的哪些提交不在另一个分支中?
- 如何取消在github上的拉请求?
- HEAD和master的区别
- GIT克隆在windows中跨本地文件系统回购
- RPC失败;卷度传输已关闭,剩余未完成的读取数据
- 我应该在.gitignore文件中添加Django迁移文件吗?
- 错误:您对以下文件的本地更改将被签出覆盖
- Git rebase—即使所有合并冲突都已解决,仍然会继续报错
- 在Git中,我如何知道我的当前版本是什么?
- 跟踪所有远程git分支作为本地分支