前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【技巧】Git提交描述骂了领导,不会删除提交记录咋办!

【技巧】Git提交描述骂了领导,不会删除提交记录咋办!

原创
作者头像
JavaDog程序狗
发布2024-10-01 18:42:49
1070
发布2024-10-01 18:42:49
举报
文章被收录于专栏:干货

前言

🍊缘由

Git提交错了?别慌,带你删除提交记录

🍍你想听的故事:

一个夜黑风高的夜晚,独自苦逼加班的狗哥默默搬砖,长时间的工作压迫,狗哥怒从心头起,恶向胆边生,稀里糊涂的将内心的愤怒写到项目注释及git提交描述中,并且push推送到了远程

清醒之后的狗哥,看到自己骚操作懊悔不已,但木已成舟,错误已犯。目前摆在狗哥面两条路:

一是降低我高傲的头颅,主动承认错误,曲意逢迎舔狗上线

二是剑走偏锋,通过狗哥强大的技术,抹平这愚蠢的失误

然而成年人不做选择题,狗哥两个全都要,当舔狗的同时,也要通过实力删除提交记录!

遂整理一下两个常用git命令:git revertgit reset,用于解决以上git尴尬问题的情况

『本故事纯属虚构如有雷同实属巧合』

******

🎯主要目标

实现2大重点
1.『git revert』命令详解
2.『git reset』命令详解

******

正文

🥦目标解析

1.『git revert』命令详解
① 作用

git revert 是 Git 中用于撤销一个或多个提交的命令,会保留历史记录

大白话解释:通俗理解吃了毒药(git commit提交)后,可以救命的解毒药(git revert),虽然可以挽救你的生命,但是会保留你吃毒药的疼痛感(历史记录)。就是能解决撤销项目注释的内容,但是撤销不了提交历史记录。

② 语法

撤销某一个提交

代码语言:shell
复制
git revert <commit-hash>

撤销多个提交

代码语言:shell
复制
git revert <commit-hash1> <commit-hash2> <commit-hash3>...

撤销最新提交

代码语言:shell
复制
git revert HEAD

撤销范围内提交

代码语言:shell
复制
git revert <commit-hash1>^..<commit-hash2>
③ 实例

上面命令没看懂,别急,来看看实操,一看就懂!

案例:撤销下图中注释提交

1. 找到commit-hash哈希码

git log 查看项目历史的 commit 记录,找到对应commit-hash哈希码git log

🎯Tips:什么是commit-hash哈希码?

Git的commit-hash哈希码,也称为commit ID或简称为hash,是Git用来唯一标识每一次提交的一个40个字符的字符串。 这个哈希码具有以下特点:

唯一性:由于SHA-1算法的碰撞概率极低,所以几乎可以认为每个不同的提交都会得到一个独特的哈希值。即使是最微小的改动,也会生成一个新的哈希。

不可篡改:由于哈希值是根据提交的所有内容计算的,一旦提交被创建,其哈希码就不能改变。如果尝试修改提交,对应的哈希码也会改变,从而破坏了Git的完整性。

2. 执行git revert <commit-hash>

执行单个文件撤销命令git revert 924c11051733c547dc16008dcc396469029a2336

3.更改提交说明

使用vim语法进行录入提交说明,如果不知晓vim语法请百度一下

  1. 执行命令后,控制台会出现vim编辑器,我们需要更改提交说明
  2. 通过vim编辑器,【按住】键盘i,进入插入模式,并通过【键盘上下/鼠标滚轮】找到最下面一行,录入更改提交说明
  3. 【按住】 Esc 键退出插入模式,并输入:wq 加回车自动保存
4.输入git push推送代码
代码语言:shell
复制
git push
5.查看提交记录

从上图看到,虽然可以撤销提交内容,但是git提交历史无法清除。斩草需除根,所以需要下面的git reset 命令

******

2.『git reset』命令详解
① 作用

通过移动 HEAD 指针并可选地更改暂存区和工作目录的状态,用于撤销提交、取消暂存文件、修改提交内容等操作

大白话解释:通俗理解吃了毒药(git commit提交)后,你拥有一台时光机(git reset),可以穿越时空,回退到你吃下毒药之前,可以销毁一切历史痕迹。

② 语法

撤销最新提交,并保留修改

代码语言:shell
复制
git reset --soft HEAD~1

撤销最新提交,并将暂存区的文件取消暂存

代码语言:shell
复制
git reset HEAD~1

撤销最新提交,并丢弃所有更改

代码语言:shell
复制
git reset --hard HEAD~1

将 HEAD 指针移动到指定commit-hash,用来回溯历史提交

代码语言:shell
复制
git reset --hard <commit-hash>
③ 实例

上面命令没看懂,别急,再来看看实操,一看就懂!

案例:撤销下图中历史提交记录

1. 查看commit 记录

git log 查看项目历史的 commit 记录,找到需要回退的指针,根据上图我们需要回退2个指针

2. 执行git reset
代码语言:shell
复制
git reset HEAD~2

git reset HEAD~2,回退2个指针

3. 强制推送远程仓库

但是我们发现云端记录还在,是因为我们还没强制推送远程仓库,需要用我们本地将云端覆盖

代码语言:shell
复制
git push --force
4. 查看历史记录

一切尘埃落定,终于完美解决了这场提交事故!

总结

本文通过git提交事故为切入点,核心介绍了git resetgit revert 两个常用命令。 git revert 用于撤销之前的提交,并创建新的提交来保持提交历史git reset 用于移动分支的指针,可以修改提交历史,但不会创建新的提交。希望这两个命令能在危急时刻帮到你,有用就点赞收藏喽。

******

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
    • 🍊缘由
      • Git提交错了?别慌,带你删除提交记录
    • 🎯主要目标
      • 实现2大重点
  • 正文
    • 🥦目标解析
      • 1.『git revert』命令详解
      • 2.『git reset』命令详解
  • 总结
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档