git仓库删除某个历史提交

目录

问题

如果我们在开发过程中,存在一些验证性的提交或者失误性的提交,那么这些提交我们不想要了,怎么办?

情况1

如果是想要删除某个commitid之后的所有提交

那么git reset 可以满足你

shell 复制代码
git reset --hard 你要保留的最近的一次提交

比如

情况2

如果是想要删除commit记录中间的某次提交

那就需要用到git rebase (变基)命令

shell 复制代码
git rebase -i 要删除的提交的前一个commitid

比如

执行命令后会进入到 vim编辑界面,如下

上面pick commitid desc 的行显示的是自目标提交之后的所有提交,默认都是pick,你可以选择你不想要的分支,将pick 改为drop。
如果想要删除某几个分支,这里可以选择对应的行,都改为drop即可

vim 默认是预览模式,英文输入法,键入i,进入插入模式,就可以修改了

然后esc,退出插入模式
键入SHIFT+:
键入wq,(表示write&quit,保存退出)

最后,强行推送到远端分支即可

shell 复制代码
git push --force origin feature/xxx
相关推荐
C137的本贾尼9 小时前
Git基本操作(四):删除文件
git
C137的本贾尼10 小时前
撤销修改:三种场景下的“反悔”操作
git
C1161110 小时前
antdesign使用git命令clone仓库后,找不到CLAUDE.md 文件什么原因
git
BoomHe13 小时前
git Rebase 为任意一笔提交补上 Change-Id
android·git·android studio
OsDepK13 小时前
AudioSplit音频多轨免费分离工具即将发布
ide·git·python·音视频·集成学习
jiayong2314 小时前
Git 常见错误与详细解决方案
大数据·git·elasticsearch
jiayong2315 小时前
Git 分支命名、区别、联系与顺序关系说明
大数据·git·elasticsearch
无风听海15 小时前
Git 对象存储模型深度解析
git
展翅飞翔的小王15 小时前
速查】Git 常用提交流程 + 强制用远端覆盖本地
git
C137的本贾尼16 小时前
分支管理(一):创建、切换与合并,体验“平行宇宙”
git