文章目录

  • 回退的两种情况
    • 1.已 commit,未push到远程仓库。
      • 1.1 git reset --soft (撤销commit)
      • 1.2 git commit --amend(修改commit 提交的内容)
      • 1.3 git reset --mixed(撤销 commit 和 add 两个动作)
    • 2.已 commit,并且push到了远程仓库。
      • 2.1 git stash save "XXX"( 如果当前已修改了代码文件,发现需要进行版本回退,可以使用,将当前文件缓存)
      • 2.2 git reset --hard 版本号(撤销并舍弃版本号之后的提交记录)
      • 2.3 git revert 版本号(撤销,但是保留了提交记录)

本文 git 相关命令:

git reset: 回退版本,可指定某一次提交的版本。git reset [--soft | --mixed | --hard] commitId

git revert: 撤销某个提交,做反向操作,生成新的commitId,原有提交记录保留。git revert commitId
git commit --amend: git commit –amend既可以对上次提交的内容进行修改,也可以修改提交说明
git status: 查看文件在工作区和暂存区的状态。

git log: 查看代码提交记录,找到需要回滚的目标版本号。

回退的两种情况

修改README.md前

回退分两种情况:

1.已 commit,未push到远程仓库。


修改README.md后

1.1 git reset --soft (撤销commit)

  • 修改了README.md,文档内容,并提交到了本地仓库
  • 此时回滚README.md,通过 git reset --soft HEAD^ 回退上一个commit

    注意: HEAD^的意思是上一个版本,也可以写成HEAD~1 ,如果你进行了2次commit,想都撤回,可以使用HEAD~2,这个命令仅仅是撤回commit操作,写的代码仍然保留

1.2 git commit --amend(修改commit 提交的内容)

  • 修改了README.md,文档内容,并提交到了本地仓库

  • 输入 git commit --amend,利用vim语法,点击i进入编辑模式,修改对应文本内容,点击Esc退出编辑模式,按键:wq强制退出


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

  • 此时已经执行add和commit两个操作,git状态是这样的

  • 输入git reset --mixed HEAD^ 撤销 commit 和 add 两个动作

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

2.1 git stash save “XXX”( 如果当前已修改了代码文件,发现需要进行版本回退,可以使用,将当前文件缓存)

  • 输入git stash save "XXX"(能够将所有未提交的修改(工作区和暂存区)保存至堆栈中,用于后续恢复当前工作目录)

  • 输入git stash pop/apply ,将当前stash中的内容弹出,并应用到当前分支对应的工作目录上。
    注:pop将堆栈中最近保存的内容删除(栈是先进后出),aplly不会删除保存的内容


    可以使用git stash apply + stash名字(如stash@{1})指定恢复哪个stash到当前的工作目录。

  • git stash clear (清除堆栈中的所有 内容)

    本文主要讲版本回退,相关缓存操作,请自行查找

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

  • git log找到要回退到的版本号,当前第五次修改已缓存尚未提交,处于第四次提交的版本,此处要回退到第三次版本

  • 输入git reset --hard be125c629a893e28f62439cf71b1e9671c73a4bb 回退到第三版本

    此时README.md文档内容为

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

    注: 通过reset的方式,此时可用看到提交记录和文件都被撤销了,reset之后,后面的版本就找不到了使用需谨慎,不推荐使用。

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

  • git log找到要回退到的版本号,当前处于第四次提交的版本,此处要回退到第三版本

  • 输入git revert -n be125c629a893e28f62439cf71b1e9671c73a4bb^..HEAD 回退到第三版本

  • 提交文件,并查看日志


    注: 这种方式不会把版本往前回退,而是生成一个新的版本。所以,你只需要让别人更新一下代码就可以了,你之前操作的提交记录也会被保留下来

git版本回退(git reset、git revert、git stash)相关推荐

  1. Git版本回退之 reset 和 revert

    在开发过程中,可能会遇到过错误提交的情况.这种情况下,先不要着急,可以通过以下两个命令来帮助你优雅的实现版本回退. git reset 假如现在有如下几个提交: 其中:A 和 B 是正常提交,而 C ...

  2. git-代码撤销、回滚到任意版本(git回滚命令reset、revert的区别)

    文章目录 一.Git 代码撤销.回滚到任意版本(当误提代码到本地或master分支时) 二.git回滚命令reset.revert的区别 1. 背景知识 2. 方法一:git reset(回退) 3. ...

  3. git 版本回退 git reset --hard HEAD

    git 版本回退 git reset --hard HEAD 一不小心用git pull拉取远程仓库代码 ,把本地开发的新代码直接覆盖掉,这时想恢复本地代码要如何操作 1.进入到项目git本地仓库文件 ...

  4. 【学了就忘】Git操作 — 26、Git中版本回退(reset --soft)详解

    文章目录 1.`git reset --soft`命令介绍 2.示例详解 git reset命令可以实现Git版本回退,其有三个选项,可以完成三种不同效果的回退. 1.git reset --soft ...

  5. git 版本回退

    现在,你已经学会了修改文件,然后把修改提交到Git版本库,现在,再练习一次,修改readme.txt文件如下: Git is a distributed version control system. ...

  6. git版本回退简单记录

    简单记录git版本回退的命令,参考的是这篇文章1 首先查看以前存档的版本: git log 1. 知道要回退的版本和现在的版本差了多少代 回退上一代版本(1个以前) git reset –hard H ...

  7. Git版本回退和撤销修改

    版本回退: 在实际工作中,我们会不断对文件进行修改,然后不断提交修改到版本库里,一旦你把文件改乱了,或者误删了文件,还可以从最近的一个commit恢复,然后继续工作,而不是把几个月的工作成果全部丢失. ...

  8. Git 版本回退和修改撤销

    文章目录 前言 一.版本回退 (撤销commit修改) 版本查看 临近版本回退 指定版本回退 git reset的模式 二.修改撤销 在工作区的修改撤销(撤销直接修改) 在暂存区的修改撤销(撤销add ...

  9. Git版本回退并强制推送到远端

    Git版本回退并强制推送到远端 本文参考廖雪峰的Git教程 前言:本文章解决问题的前提是本人不小心修改了本地代码仓库的最外层目录权限,不知道原权限是什么,导致本地git提示几十个文件被修改过,实际内容 ...

  10. idea中 git版本回退

    1.版本回退 之 Reset Type 有四种: 1.1.soft ①移动本地库HEAD指针 意思就是,回滚后,仅仅是把本地库的指针移动了,而暂存区和你本地的代码是没有做任何改变的.而你上次改动已提交 ...

最新文章

  1. 使用GoldenGate进行平台迁移和数据库升级(9i-11g)步骤描述
  2. app启动广告页的实现,解决了广告图片要实时更新的问题
  3. python开课吧1980课程_开课吧的课程怎么样?
  4. ARM中断分析之一:中断控制器和CPU、外设的关系
  5. linux看系统硬件,Linux 查看系统硬件信息(实例详解)
  6. php 去年年初和年底时间,PHP 日期与时间
  7. 阿里研究院:2020阿里农产品电商报告
  8. 用ExtJs+Linq+Wcf打造简单grid
  9. java list类_java_List集合及其实现类
  10. Unity播放声音的两种方式以及相关遇到的
  11. ELK系列~NLog.Targets.Fluentd到达如何通过tcp发到fluentd
  12. 编程语言对高手没有差别,对低手差别太明显
  13. c语言数组输入空格回车问题
  14. 超级电容充放电时间计算
  15. MySQL 聚集索引(InnoDB)和 非聚集索引(MyISAM) 精讲~两张图彻底搞懂
  16. 整理18、19、20年关于《人工智能》的标准和评估规范
  17. 十个经典java开发项目及其描述-简历用
  18. 头歌-数据结构与算法 - 线性表
  19. 冻干机计算机系统验证方案,冻干机验证方案最新
  20. UE4播放视频与声音

热门文章

  1. px4原生源码学习-(1)
  2. 算法笔记之回溯法(一)——溯洄从之,道阻且长;溯游从之,宛在水中央。
  3. 关于Echarts折线图双Y轴网格的一些配置
  4. 氢os关闭android键盘,氢OS11到来前,先听听这些一加用户对氢OS的吐槽
  5. 林深时见鹿,海蓝时见鲸
  6. win10不识别移动硬盘
  7. 《数据结构》八大排序(详细图文分析讲解)
  8. IOS下载资源zip到本地然后读取
  9. 如何快速搭建自己的云桌面和云办公服务器软件系统
  10. TSINGSEE车载视频监控技术在城市公交场景中的应用