git撤销第一次commit

前言

使用git时会遇到的情况是很多样的,需要记住的命令不是一般的多,为了方便下次遇到类似情况可以快速找到应该采用的命令,我决定把具体情况时要使用到的命令记录下来。

这次碰到的具体情况是,我才为我的后端springboot项目创建了本地仓库,进行第一次提交,误把application.yml中的敏感信息(如阿里云oss访问密钥)提交到了仓库中😢

与一般情况的不同之处

这种情况与正常的有多次提交撤销最近一次提交的处理方式是不同的,我们试着理解一下

有多次提交撤销最近一次

有多个commit

sql 复制代码
commit A (first) <- commit B <- commit C (HEAD)

每个commit都会有一个parent指针指向前一个commit。 我们的目标是删除commit C,那么只需要使得HEAD移动到当前HEAD的parent commit即可。

这样commit C虽然任然存在,但是不会再被引用,相当于删除了,变成了如下情况

sql 复制代码
commit A (first) <- commit B (HEAD) <- commit C

撤销第一次提交

但是我的情况是,只有一个commit

sql 复制代码
commit A (HEAD, first)

如果我按照多次提交撤销最近一次的方法的话,会发现回不到HEAD的parent commit

解决方法

我们可以执行以下指令

sql 复制代码
git update-ref -d HEAD

执行前后对比

rust 复制代码
# 之前
HEAD -> refs/heads/master -> commit A
​
# 之后  
HEAD -> (deleted)
refs/heads/master -> (deleted)
commit A -> (仍存在但无引用)

执行结果就是

  • HEAD引用被删除: 不再指向任何commit
  • master分支被删除: 分支引用消失
  • commit对象保留: commit A 的数据还在.git目录中
  • 工作目录不变: 您的文件完全不受影响
相关推荐
艾莉丝努力练剑10 小时前
【Git:基本操作】深度解析Git:从初始Git到熟悉基本操作
大数据·linux·c++·人工智能·git·gitee·指令
大白要努力!11 小时前
将Git项目的所有远程分支打包成压缩包文件
git
牧羊人_myr11 小时前
Git指令集
git
边疆.13 小时前
【Linux】版本控制器Git和调试器—gdb/cgdb的使用
linux·服务器·git·gdb调试·cgdb
安冬的码畜日常1 天前
【JUnit实战3_22】 第十三章:用 JUnit 5 做持续集成(下):Jenkins + JUnit 5 + Git 持续集成本地实战演练完整复盘
git·测试工具·ci/cd·jenkins·集成测试·持续集成·junit5
wxxka1 天前
git使用
开发语言·git
舒一笑1 天前
用数据照亮成长之路:PandaCoder Git 统计工具窗口
git·后端·intellij idea
测试修炼手册1 天前
[测试工具] 如何把离线的项目加入成为git项目的新分支
git
递归不收敛2 天前
专属虚拟环境:Hugging Face数据集批量下载(无登录+国内加速)完整指南
人工智能·笔记·git·python·学习·pycharm