前言
🍊缘由
Git提交错了?别慌,带你删除提交记录
🍍你想听的故事:
一个夜黑风高的夜晚,独自苦逼加班的狗哥默默搬砖,长时间的工作压迫,狗哥怒从心头起,恶向胆边生,稀里糊涂的将内心的愤怒写到项目注释及git提交描述中,并且push推送到了远程。
清醒之后的狗哥,看到自己骚操作懊悔不已,但木已成舟,错误已犯。目前摆在狗哥面两条路:
一是降低我高傲的头颅,主动承认错误,曲意逢迎舔狗上线
二是剑走偏锋,通过狗哥强大的技术,抹平这愚蠢的失误
然而成年人不做选择题,狗哥两个全都要,当舔狗的同时,也要通过实力删除提交记录!
遂整理一下两个常用git命令:git revert 和 git reset,用于解决以上git尴尬问题的情况
『本故事纯属虚构如有雷同实属巧合』
🎯主要目标
实现2大重点
1.『git revert』命令详解
2.『git reset』命令详解
正文
🥦目标解析
1.『git revert』命令详解
① 作用
git revert 是 Git 中用于撤销一个或多个提交的命令,会保留历史记录
大白话解释:通俗理解吃了毒药(git commit提交)后,可以救命的解毒药(git revert),虽然可以挽救你的生命,但是会保留你吃毒药的疼痛感(历史记录)。就是能解决撤销项目注释的内容,但是撤销不了提交历史记录。
② 语法
撤销某一个提交
git revert <commit-hash>
撤销多个提交
git revert <commit-hash1> <commit-hash2> <commit-hash3>...
撤销最新提交
git revert HEAD
撤销范围内提交
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
执行单个文件撤销命令
git revert 924c11051733c547dc16008dcc396469029a2336
3.更改提交说明
使用vim语法进行录入提交说明,如果不知晓vim语法请百度一下
- 执行命令后,控制台会出现vim编辑器,我们需要更改提交说明
- 通过vim编辑器,【按住】键盘i,进入插入模式,并通过【键盘上下/鼠标滚轮】找到最下面一行,录入更改提交说明
- 【按住】 Esc 键退出插入模式,并输入:wq 加回车自动保存
4.输入git push推送代码
git push
5.查看提交记录
从上图看到,虽然可以撤销提交内容,但是git提交历史无法清除。斩草需除根,所以需要下面的git reset 命令
2.『git reset』命令详解
① 作用
通过移动 HEAD 指针并可选地更改暂存区和工作目录的状态,用于撤销提交、取消暂存文件、修改提交内容等操作
大白话解释:通俗理解吃了毒药(git commit提交)后,你拥有一台时光机(git reset),可以穿越时空,回退到你吃下毒药之前,可以销毁一切历史痕迹。
② 语法
撤销最新提交,并保留修改
git reset --soft HEAD~1
撤销最新提交,并将暂存区的文件取消暂存
git reset HEAD~1
撤销最新提交,并丢弃所有更改
git reset --hard HEAD~1
将 HEAD 指针移动到指定commit-hash,用来回溯历史提交
git reset --hard <commit-hash>
③ 实例
上面命令没看懂,别急,再来看看实操,一看就懂!
案例:撤销下图中历史提交记录
1. 查看commit 记录
git log 查看项目历史的 commit 记录,找到需要回退的指针,根据上图我们需要回退2个指针
2. 执行git reset
git reset HEAD~2
git reset HEAD~2,回退2个指针
3. 强制推送远程仓库
但是我们发现云端记录还在,是因为我们还没强制推送远程仓库,需要用我们本地将云端覆盖
git push --force
4. 查看历史记录
一切尘埃落定,终于完美解决了这场提交事故!
总结
本文通过git提交事故为切入点,核心介绍了git reset 和 git revert 两个常用命令。 git revert 用于撤销之前的提交,并创建新的提交来保持提交历史;git reset 用于移动分支的指针,可以修改提交历史,但不会创建新的提交。希望这两个命令能在危急时刻帮到你,有用就点赞收藏喽。
🍈猜你想问
如何与狗哥联系进行探讨
关注公众号【JavaDog程序狗】
公众号回复【入群】或者【加入】,便可成为【程序员学习交流摸鱼群】的一员,问题随便问,牛逼随便吹,目前群内已有超过200+个小伙伴啦,只能拉人入群啦!!!
此群优势:
- 技术交流随时沟通
- 任何私活资源免费分享
- 实时科技动态抢先知晓
- CSDN资源免费下载
- 本人一切源码均群内开源,可免费使用
2.踩踩狗哥博客
大家可以在里面留言,随意发挥,有问必答
🍯猜你喜欢
文章推荐
【苹果】SpringBoot监听Iphone15邮件提醒,Selenium+Python自动化抢购脚本
【项目实战】SpringBoot+uniapp+uview2打造H5+小程序+APP入门学习的聊天小项目
【项目实战】SpringBoot+uniapp+uview2打造一个企业黑红名单吐槽小程序
【模块分层】还不会SpringBoot项目模块分层?来这手把手教你!
【ChatGPT】SpringBoot+uniapp+uview2对接OpenAI,带你开发玩转ChatGPT