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 <分支名>
相关推荐
10000hours2 小时前
【Git】git常用命令
git
KevinRay_2 小时前
Github如何上传项目(超详细小白教程)
git·gitee·开源·github·vim
乖乖是干饭王11 小时前
GIT仓库本地部署
git
-拟墨画扇-17 小时前
Git | 分支管理操作
git·gitee·github·gitcode
ModestCoder_17 小时前
Git 版本管理教程
大数据·git·elasticsearch
YMGogre17 小时前
Git 提交信息规范
git
charlie11451419118 小时前
Git团队协作完全入门指南(下)
git
golang学习记20 小时前
Facebook 为什么不用 Git?
git·elasticsearch·facebook
GIS阵地21 小时前
git拉取时报错
大数据·git·elasticsearch