git --- reset 删除提交

git --- reset 删除提交

如果要删除最近的几个提交,可以使用 git reset 命令

  • 但是删除最近的提交最好的方法是使用revert, 而不是本篇文章使用的reset

保留修改

git reset --soft HEAD~N

删除提交历史,但保留工作区(已修改的文件)和暂存区(git add 的内容)的修改。

c 复制代码
# 删除最近1个提交(保留修改)
git reset --soft HEAD~1

# 删除最近3个提交(保留修改)
git reset --soft HEAD~3

适用场景:提交信息写错了,想重新提交;或者多个小提交想合并后重新提交。

清空暂存区

bash 复制代码
git reset HEAD~N

删除提交历史,保留工作区修改,但清空暂存区(需要重新 git add)

c 复制代码
# 删除最近1个提交(清空暂存区)
git reset HEAD~1  # 等同于 git reset --mixed HEAD~1

适用场景:想重新整理暂存区的文件,再重新提交。

彻底丢弃修改(危险)

c 复制代码
git reset --hard HEAD~1

删除提交历史,同时丢弃工作区和暂存区的所有修改(无法恢复)。

c 复制代码
# 删除最近1个提交(彻底丢弃修改)
git reset --hard HEAD~1
适用场景:确定这些修改完全不需要,想回到之前的干净状态。

删除中间的提交(本地)

如果要删除历史中的某个特定提交(非最近的),需要使用 git rebase -i(交互式变基)

操作步骤

  1. 查看提交历史,找到要删除的提交的前一个提交 ID:
bash 复制代码
git log --oneline
# 示例输出:
# a1b2c3d (HEAD) 最近的提交
# d4e5f6g 要删除的提交 ← 目标
# g7h8i9j 更早的提交
  1. 执行交互式变基,范围是从要删除的提交的前一个开始:
bash 复制代码
# 格式:git rebase -i <要删除的提交的前一个提交ID>
git rebase -i g7h8i9j
  1. 在编辑器中删除目标提交:编辑器会显示提交列表,将目标提交行的 pick 改为 drop(或直接删除该行):
bash 复制代码
# 原内容:
pick d4e5f6g 要删除的提交
pick a1b2c3d 最近的提交

# 修改为(二选一):
drop d4e5f6g 要删除的提交  # 方法1:改为 drop
pick a1b2c3d 最近的提交

# 或直接删除目标提交行(方法2):
pick a1b2c3d 最近的提交
  1. 保存退出编辑器,Git 会自动完成变基,目标提交被删除

删除远程仓库的提交

如果提交已经推送到远程仓库(如 GitHub/GitLab),需要强制推送来覆盖远程历史。

  • 先删除本地提交, 使用上述 git reset 或 git rebase -i 方法删除本地提交。
  • 强制推送到远程
bash 复制代码
# 方法1:基本强制推送(简单但风险较高)
git push -f origin <分支名>

# 方法2:安全强制推送(推荐,会检查远程是否有新提交)
git push --force-with-lease origin <分支名>
相关推荐
H Journey12 小时前
Git 教程
git
蜜汁小强20 小时前
macOS 上的git代理配置在哪里
git·macos·代理模式·proxy模式
钟佩颖21 小时前
Git .
git
Zhongyi_Li1 天前
git merge的一些记录
git
沛沛老爹1 天前
Web开发者转型AI:Agent Skills版本控制与管理实战——从Git到AI技能仓库
java·前端·人工智能·git·架构·rag
子琦啊1 天前
极速移除 Git 历史中的大文件,告别 git filter-branch太慢的问题
git
儒雅的晴天1 天前
git笔记
笔记·git
Ama_tor2 天前
git bash|下载、安装与配置(Windows11)
git
惜__缘2 天前
Git项目迁移的坑点
git
阿杰 AJie2 天前
Git 分支与多人开发使用指南(Gitee + 本地 Git)
git·elasticsearch·gitee