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 <分支名>
相关推荐
小李不困还能学21 小时前
用git GUI往远程仓库中添加文件/文件夹
git
失途老马1 天前
Git Patch 生成与应用完整操作手册
git
李白的天不白1 天前
下载smartadmin框架
git·github
可乐要加冰^-^1 天前
云雀文档下载
windows·git·github·石墨文档
NaclarbCSDN1 天前
我写了一个命令行书签管理器,然后抛弃了浏览器书签栏
linux·git·python·github
++==1 天前
git的安装以及基本命令使用、远程仓库的操作、vscode连接远程仓库进行项目的上传、gitee的使用
linux·git·gitee
kyriewen1 天前
Git Commit 前自动修复代码风格?配置 Husky + lint-staged,从此 CR 只聊逻辑
前端·git·面试
吹牛不交税2 天前
visualstudio把项目绑定git仓库
git
c238562 天前
git常见错误和ssh验证推送
运维·git·ssh
火山上的企鹅2 天前
Codex实战:APP远程升级服务搭建(四)Node 服务端自动识别 APK 信息
android·服务器·git·github·qgc