需求
在工作中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命令。