0


学习 | Git 的几种回退方法

纯纯的一边开发一边学习,是小白是菜鸟,单纯的记录和学习,大神勿喷,理解有错望指正~

想必都会在git提交的时候失误过,提交了不应该提交的代码,那么应该如何回退?

一、查看commit-id(哈希码)

与回退息息相关的是

commit-id

,也就是哈希码,如何得到这个

commit-id

呢?
两种写法,如下所示:

git log
// 四行详细记录,包括的信息有commit-id、提交者、提交时间、备注

 git log --pretty=oneline
//输出的每个提交记录只占据一行,每行的显示内容为commit-id + 备注

在这里插入图片描述

在这里插入图片描述


二、回退到指定的版本,并保留更改

通过git log查看id,最上方的就是最新的提交记录,应该会出现你提交错误的那条记录,下面开始进行回退:

1、回退到指定版本,这个方法回退比较灵活,可以选择回退到指定的记录。
git reset <commit-id>
<commit-id>

写你想要回退到的那个版本的id,不要选择最新的,如果选择最新的则没回退有效果。

<commit-id>

后面的提交记录都会被删除,但是不会删除代码,会把代码放在暂存区。

2、快捷回退上一版本,没有特殊,只是回到上一次。

如果要回退到上一个版本,可以使用以下 Git 命令,此命令也会保留更改,不会删除代码,会把代码放在暂存区:

git reset HEAD^

这个命令将会将当前版本回退到上一个版本,

HEAD^

表示上一个版本,

HEAD^^

表示上上个版本。

如果想回退更多个版本,用

HEAD~n

即可,比如回退到前5个版本:

git reset HEAD~5

三、回退到指定版本,不保留更改

回退的同时,将代码和commit记录都将回退到指定版本,

放弃目标版本以后的所有修改

,灵活回退,但是不会保留代码。

git reset --hard <commit-id>

四、回退到指定版本,保留commit记录

该命令会回退指定版本的修改,撤销文件后不会影响其他的提交。

// 撤销某个提交,并创建一个新的提交。
git revert <commit-id>
// 撤销某个提交,但执行命令后不进入编辑界面,也就是不会自动帮你提交文件,需要手动提交// 这与第1点的差别就是撤销和提交分开了。
git revert --no-commit <commit-id>

参考链接:(详解踩坑)GIT版本回滚git stash、git reset、git reset --hard、git revert

参考链接:git revert是个好东西

参考链接:git中revert的最简单、最直观的理解

标签: 学习 git

本文转载自: https://blog.csdn.net/weixin_58951442/article/details/137506760
版权归原作者 weixin_58951442 所有, 如有侵权,请联系我们删除。

“学习 | Git 的几种回退方法”的评论:

还没有评论