为了账号安全,请及时绑定邮箱和手机立即绑定

撤销提交

标签:
Git

使用方法

该指令可以用于撤销提交、重置暂存区或工作区。

git reset

执行 git log,列出所有提交记录:

$ git checkout main
$ git log
commit ff3490694a2168a94abc0188fe35cdd102d3c7fc (HEAD -> main, origin/main)
Author: zhanglianwei <zhanglianwei@meituan.com>
Date:   Wed Feb 21 16:09:29 2024 +0800

    第二次修改iss53

commit b0a67cb1bbd16e8a812516dad50b129961f483f7
Author: zhanglianwei <zhanglianwei@meituan.com>
Date:   Wed Feb 21 16:02:42 2024 +0800

    修改iss52

commit 9f5bfba20b0448961111fe1cc621187b461284c4
Author: zhanglianwei <zhanglianwei@meituan.com>
Date:   Wed Feb 21 16:00:55 2024 +0800

    修改hotfix

commit ca5ebf0f7e0438c514b9039594e86b6bc1ef64e2
Author: zhanglianwei <zhanglianwei@meituan.com>
Date:   Tue Jan 30 16:24:42 2024 +0800
:

图片描述

根据不同的参数,git reset 可以实现不同的功能。

移动 HEAD( --soft )

$ git reset --soft HEAD^ # 也可以使用哈希值 git reset --soft b0a67cb

执行该指令之后,GIT 移动 HEAD 指向 main 分支最后一次提交(哈希值 ff34906)的父提交(哈希值 b0a67cb),相当于撤销最后的提交并将最后提交的修改内容保留在暂存区。
并且,该指令不会覆盖暂存区和工作区。

图片描述

Sourcetree 截图显示,本地 main 分支已经回退一个版本,而 Uncommitted changes 表明,暂存区或工作区存在未提交的更改。
最后,通过 git push -f 强制更新服务器的提交记录即可。

图片描述

覆盖暂存区和工作区(–hard)

$ git reset --hard HEAD^ # 也可以使用哈希值 git reset --hard b0a67cb
HEAD is now at b0a67cb 修改iss52

--hard 标记会移动 HEAD 指向 main 分支最后一次提交的父提交,并且强制覆盖暂存区和工作区的文件,无法恢复。
也就是说,该指令会撤销最后的提交,暂存区和工作区中的所有工作也会被销毁。

图片描述

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
Web前端工程师
手记
粉丝
1.4万
获赞与收藏
860

关注作者,订阅最新文章

阅读免费教程

  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消