目录
- 问题
- 情况1
- 情况2
问题
如果我们在开发过程中,存在一些验证性的提交或者失误性的提交,那么这些提交我们不想要了,怎么办?
情况1
如果是想要删除某个commitid之后的所有提交
那么git reset 可以满足你
git reset --hard 你要保留的最近的一次提交
比如
情况2
如果是想要删除commit记录中间的某次提交
那就需要用到git rebase (变基)命令
git rebase -i 要删除的提交的前一个commitid
比如
执行命令后会进入到 vim编辑界面,如下
上面pick commitid desc 的行显示的是自目标提交之后的所有提交,默认都是pick,你可以选择你不想要的分支,将pick 改为drop。
如果想要删除某几个分支,这里可以选择对应的行,都改为drop即可
vim 默认是预览模式,英文输入法,键入i,进入插入模式,就可以修改了
然后esc,退出插入模式
键入SHIFT+:
键入wq,(表示write&quit,保存退出)
最后,强行推送到远端分支即可
git push --force origin feature/xxx