版本回退

前面我们成功的提交了一次mygit.txt,下面咱对它进行修改,内容如下:

Hello Git
Git is so easy.

然后用git status来跟踪该文件的状态:

可以看到hellogit.txt已经被修改过了,到底这次修改的内容与上次的内容有什么不同的,咱们可以使用git diff查看:

当然你也可以查看上次提交的信息,使用git log:

通过前面一章我们知道,该文件还处于工作区,因此我们又可以使用add、commit操作了:

这里笔者偷了个懒,直接用-m表示提交的信息,当然在学习过程中咱可以这样,但实际工作中一般不这么写。

好了,提交完后咱再用git status来跟踪一下(建议多使用git status)状态:

这里依然是:Git告诉咱们当前没有需要提交的修改,而且工作目录是干净的。

下面再学一个命令:git reflog,它主要用来记录你的每一次命令和commit id,这个命令非常有效,也建议大家常用。

可以看到咱提交的id号和提交的message被显示出来了。

加入你现在不想修改了,想回到原来那个版本,该怎么办呢?别急,这一点Git早就帮我们想好了,使用git reset --hard HEAD^

注意:这里HEAD上面^表示回到上一个版本,如果想回到前面第五个版本呢?我们可以用git reset --hard HEAD~5,当然因为我们这里只修改了1次,所以我们最多只能回到前面一个版本。打开hellogit.txt看看,是内容不是Hello Git呢?当然如果你又想修改回去,那么咱们还有办法,用git reset --hard commit-id:

注意:这里的e75e865指的是commit id,上面已经说了,这里就不再赘述。

撤销修改:

下面我们再次对helliogit.txt进行修改,内容如下:

Hello Git
Git is so easy.
Easily learn the Git.

然后我们用git status跟踪状态:

这里Git会告诉你,git checkout -- file可以丢弃工作区的修改:

命令git checkout -- readme.txt意思就是,把readme.txt文件在工作区的修改全部撤销,然后在查看状态:

工作目录有变回”clean“了,查看hellogit.txt内容 cat hellogit.txt

内容又改回来了,这样就完成了一次简单的修改撤销。如果你把文件内容修改为原来添加时的:

Hello Git
Git is so easy.
Easily learn the Git.

git add hellogit.txt到了暂存区,咱们还有办法,使用git reset HEAD hellogit.txt来返回到工作区状态:

竟然已经回到了工作区,那么咱们就可以向之前那样,使用git checkout -- hellogit.txt了:

好了,一切又回到了,原来的状态。如果你还从暂存区提交到了版本库,还记得上面的版本回退吗?可以回到上一个版本就OK了,不过如果你还将本地的修改推送到远程版本库(后面会讲),那就没有后悔药吃了。

删除文件

前面已经说了,在Git中,删除也算一个修改操作。下面咱们先添加一个新文件1.txt到Git并且提交:

这是你如果执行rm 1.txt把1.txt文件删了,那么这个时候,Git知道你删了文件,工作区和版本库就不一致了,我们再用git status跟踪一下:

这是你有两个选择,一是确实要从版本库中删除,使用git rm 1.txt并commit一下:

注意:你删除之后,你只能恢复文件到最新版本,你会丢失最近一次提交后你修改的内容。

另一种情况,你觉得你删除了想修改过来,因为版本库中还存在,所以可以很轻松地把误删的文件恢复到原来版本。

可以看到,1.txt有回到工作区了。

总结

今天内容比较多,可能需要点时间慢慢消化,如果有哪里写的不对多需要改进或哪里的地方可以留言,我现在的工作很闲。明天开始讲远程仓库。

Git学习系列(三)版本回退和管理文件的修改及删除操作相关推荐

  1. git版本回退命令_Git学习版本回退和管理文件的修改及删除操作

    版本回退 前面我们成功的提交了一次mygit.txt,下面咱对它进行修改,内容如下: Hello Git Git is so easy. 然后用git status来跟踪该文件的状态: 可以看到hel ...

  2. Git学习系列(二)创建本地仓库及文件操作

    2019独角兽企业重金招聘Python工程师标准>>> 仓库(repository ),我们也成它为版本库.这个库里面的所有文件(包括对文件的添加.删除.修改等操作)都被Git管理起 ...

  3. idea学习系列三之版本管理工具

    idea学习系列三之版本管理工具 上一篇文章主要介绍了将idea中常用的快捷键,快捷键要想熟练那就得在实际的工作中多使用,刚开始可能很麻烦经常去笔记中找,不过用多了自然就熟练了. 这篇文件将会介绍一下 ...

  4. 数据库MYSQL学习系列三

    数据库MYSQL学习系列三 三.MYSQL事务与存储引擎 3.1-数据库事务 什么是事务 一系列有序的数据库操作: o要么全部成功 o要么全部回退到操作前的状态 o中间状态对其他连接不可见 事务的 ...

  5. Git学习系列之如何正确且高效地将本地项目上传到Github(图文详解)

    不多说,直接上干货! 首先你需要一个Github账号,所以还没有的话先去注册吧! https://github.com/ 见 如何走上更高平台分享传递干货知识:(开通个人Github面向开源及私有软件 ...

  6. Git学习系列之Git基本操作提交项目(图文详解)

    前面博客 Git学习系列之Git基本操作克隆项目(图文详解) 然后可以 cd 切换到 LispGentleIntro 目录, 新增或者修改某些文件.这里只是模拟一下操作, 实际情况可能是 使用 Ecl ...

  7. Git学习系列之Windows上安装Git之后的一些配置(图文详解)

    不多说,直接上干货! 前面博客 Git学习系列之Windows上安装Git详细步骤(图文详解) 第一次使用Git时,需要对Git进行一些配置,以方便使用Git. 不过,这种配置工作只需要进行一次便可, ...

  8. jQuery框架学习第三天:如何管理jQuery包装集

    jQuery框架学习第一天:开始认识jQuery jQuery框架学习第二天:jQuery中万能的选择器 jQuery框架学习第三天:如何管理jQuery包装集 jQuery框架学习第四天:使用jQu ...

  9. Git教程之如何版本回退

    一.前言 上一章节,我们已经学会了如何创建版本库,如何提交文件到版本库,如何查看最近提交文件的记录,那么如果现在我们想回退版本怎么操作呢? 二.步骤 ①现在继续对readme.txt文件进行修改,再增 ...

最新文章

  1. 九爷带你了解 nginx 日志配置指令详解
  2. 程序员外包避坑指南?
  3. c linux 判断ip合法_shell 检测ip的合法性与检测网络掩码的合法性
  4. OpenShift 4 - 节点是如何通过CRI-O运行容器的
  5. linux下,如何迁移mysql数据库存放目录。利用软连接简单快捷实现移动到home数据盘下...
  6. [导入]表单确认按钮——Javascript函数
  7. 《Redis开发与运维》学习第五章
  8. JBOSS的下载安装、环境变量配置以及部署
  9. 技术分享 | MaxScale 实现 MySQL读写分离
  10. 实用思维导图、流程图模板合集,让你的头脑灵活起来
  11. Ceisum 计算向量夹角及垂足
  12. 解决使用ssh工具远程连接到服务器上因为网络波动而需要重连的问题
  13. style标签中的几个属性
  14. 子网掩码起什么作用?
  15. Ubuntu 下编写C程序
  16. UWB_安信可NodeMCU-BU01的使用
  17. SCM工具-Git的相关指令
  18. mysql 数据文件_mysql的数据文件
  19. 如何给apk安装包去毒,避免被识别为病毒和木马
  20. 消除SDK更新时的“https://dl-ssl.google.com refused”错误

热门文章

  1. 三周第三次课(12月27日)
  2. Jetty插件实现热部署(开发时修改文件自动重启Jetty)
  3. VBS去除指定的字符串中的重复项返回重复后的字符串
  4. 今年7月,一起来看谷歌如何测试移动应用!
  5. OpenWrt中对USB文件系统的操作, 以及读写性能测试
  6. mysql innodb_double_write特性
  7. python中的编码问题 1
  8. SQL查询集合合并成字符串
  9. mysql Slave_IO_Running:NO(解决方法)
  10. 第一章 架构 1.4 编译 amp; 1.5总结