需求
在工作中git commit后,发现问题,需要删除某几个提交。
解决方法
可以使用“git rebase -i hash-id-you-want-to-delete~1 (可以再加一个参数,默认是HEAD)”来操作hash-id-you-want-to-delete到最后一个参数之间的commit。
具体步骤
先执行
git log
查看你想要删除的commit id,然后复制它的前一次commit id,输入
git rebase -i hash-id-you-want-to-delete~1 (可以选择再加一个参数,默认是HEAD)
此时会弹出一个文本编辑器,把你想要删除的commit id前的pick改为drop,保存这个文件。再退出就完成了。失败的话就按它的提示,执行git rebase --edit编辑或者git rebase --abort撤销。再失败就git reflog找到想恢复的id恢复吧。
注意
当一个你想删除提交涉及到merge,那么弹出的文本就会有点难处理,要追溯到merge的源头的提交。这个需要你再看看其他资料,不是使用drop,而是要涉及到merge命令。
本文详细介绍了如何在Git中通过`gitrebase-interactive`删除不需要的提交,包括查找commitID、编辑操作流程,以及处理涉及合并的特殊情况。
1201

被折叠的 条评论
为什么被折叠?



