git版本回退操作

git版本回退操作搞懂 git 回退命令 如果不慎提交 可通过 gitreset gitrevert 来撤销操作

git版本回退操作

本文 git 相关命令:

  • git reset:回退版本,可指定某一次提交的版本。git reset [–soft | –mixed | –hard] commitId。
  • git revert:撤销某个提交,做反向操作,生成新的commitId,原有提交记录保留。git revert commitId。
  • git status:查看文件在工作区和暂存区的状态。
  • git log:查看代码提交记录。
  • git cherry-pick:选择commitId 应用在当前分支。git cherry-pick commitId。

回退分两种情况:

  • 已 commit,未push到远程仓库。
  • 已 commit,并且push到了远程仓库。

已 commit,未push到远程仓库

git reset –soft(撤销commit)

touch 创建了一个a.text,并提交到了本地仓库。

git版本回退操作

此时回滚a.text,git log找到要回退到的版本号,此处版本号为前一个版本。(或者通过 git reset [HEAD] 回退版本)

git版本回退操作

执行命令:git reset –soft 7ee5305f1e1e0f66c7d69666ff7054fc6e

git版本回退操作

通过idea可看到commit 记录被撤销了。

git版本回退操作

git reset –mixed(撤销 commit 和 add 两个动作)

touch创建新文件 b.text, 并提交到本地仓库。

git版本回退操作

通过git log找到要回退到的版本号 7ee5305f1e1e0f66c7d69666ff7054fc6e

执行命令:git reset –mixed 7ee5305f1e1e0f66c7d69666ff7054fc6e

git版本回退操作

git版本回退操作

此时可以看到,git reset –mixed 撤销的文件 未加入到暂存区,所以是撤销 commit 和 add 两个动作。

已 commit,并且push到了远程仓库

git reset –hard(撤销并舍弃版本号之后的提交记录)

新建文件a.text,并push到远程。

git版本回退操作

执行命令:

  • git reset –hard 7ee5305f1e1e0f66c7d69666ff7054fc6e
  • git push -f(强制推送到远程,之前提交都会被覆盖,慎用)

git版本回退操作

此时可用看到提交记录和文件都被撤销了。使用需谨慎,不推荐使用。


当然,如果不小心用了git reset –hard操作回退了,那么可用git reflog命令查看命令历史,找到被删除的commit,再次操作。

git版本回退操作

git revert(撤销,但是保留了提交记录)

新建文件a.text,并push到远程。

通过 git revert 版本号,撤销当前提交记录。版本号为要撤销的版本号,此处为当前提交的版本号。

git版本回退操作

可以看到本地和远程仓库文件都被撤销了。但是git log中能看到提交和撤销记录。

推荐用这种方式回退远程的代码。比如我们在master分支提交错了文件需要回退,那么我们用这个方式回退后,再用git cherry-pick commitId 重放该提交。最后本地修改了再push到远程。

git版本回退操作

总结

回退分两种情况:

  1. 已 commit,未push到远程仓库。
    • git reset –mixed(撤销 commit 和 add 两个动作)。

    git reset –soft(撤销commit)。

  2. 已 commit,并且push到了远程仓库。
    • git revert(撤销,但是保留了提交记录)。

    git reset –hard(撤销并舍弃版本号之后的提交记录)。

git版本回退操作

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/233408.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Window server 2012 R2 AD域的组策略设置

    Window server 2012 R2 AD域的组策略设置1.AD域的组策略添加有助于管理AD域中的用户使用的client端的环境。2.组策略依附于AD域的OU构成3.使用“gpmc.msc”在运行里面打开,或者是在“开始—管理工具”里面打开4.在打开的组策略管理界面里面,林kaka下的DefaultDomainPolicy为全局策略,而只对计算机做了配置。 一、简单组策略的建立实现:来做一个实例说明组策略的简单实现:要求:

    2022年5月13日
    45
  • APK签名原理

    APK签名原理网上已有多篇分析签名的类似文章,但是都有一个共同的问题,就是概念混乱,混乱的一塌糊涂。在了解APK签名原理之前,首先澄清几个概念:消息摘要-MessageDigest简称摘要,请看英文翻译,是摘要,不是签名,网上几乎所有android签名分析的文章都对这两个概念乱用摘要的链接http://en.wikipedia.org/wiki/Message_digest简

    2022年6月12日
    29
  • 深度学习中的9种归一化方法概述

    深度学习中的9种归一化方法概述9种归一化(Normalization)方法概述

    2025年7月4日
    3
  • navicat生产激活码失败【中文破解版】

    (navicat生产激活码失败)JetBrains旗下有多款编译器工具(如:IntelliJ、WebStorm、PyCharm等)在各编程领域几乎都占据了垄断地位。建立在开源IntelliJ平台之上,过去15年以来,JetBrains一直在不断发展和完善这个平台。这个平台可以针对您的开发工作流进行微调并且能够提供…

    2022年4月1日
    203
  • 经典汉罗塔问题解决方案[通俗易懂]

    经典汉罗塔问题解决方案[通俗易懂]汉罗塔问题将a的盘子移动到c针且一次只能移动一个盘,在移动过程中必须保持大盘在下,小盘在上。1、将n-1个盘子从a移动到b盘2、将a剩下的一个盘子移动到c盘3、将b的n-1个盘子移动到c盘#include<iostream>usingnamespacestd;voidmove1(chara,charc){ cout<<a<<“–>”<<c<<endl;}voidhanoi(intn,

    2022年8月31日
    5
  • Linux 5nd Day

    Linux 5nd Day

    2021年8月7日
    54

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号