git 删除文件

git删除文件包括以下几种情况

  1. 删除本地文件,但是未添加到暂存区;
  2. 删除本地文件,并且把删除操作添加到了暂存区;
  3. 把暂存区的操作提交到了本地git库;
  4. 把本地git库的删除记录推送到了远程服务器github。

git对于删除操作有极大的撤销空间,下面分别针对上面4种情况进行恢复操作。

一、删除了本地文件,但未添加到暂存区;

选择要删除的文件12.md

删除本地文件12.md

此时发现删除错误了要进行恢复操作

恢复文件

二、删除了本地文件,并且已经把删除操作添加到了暂存区

删除本地文件

通过git status查看状态


查看删除状态

看提示可以知道,此时如果操作 git checkout 12.md 可以恢复删除文件
如果操作 git add/rm 12.md 可以把删除状态添加到暂存区
我们进行添加操作


添加到暂存区

查看状态,可以知道删除操作已经被添加到了暂存区,
查看添加状态

此时如果要撤销操作,从提示可以知道,进行 git reset HEAD 12.md可以把删除操作退回到本地删除状态,然后按照上面1的操作就可以恢复文件
从暂存区回滚

恢复文件

三、从暂存区把删除操作提交到了本地git库

提交删除操作

查看状态 git status

查看删除状态

可以看到有一个提交改动,此时如果要撤销,就必须对git进行版本回滚操作
通过 git log 命令查看git库的所有版本信息

查看git库版本

如果感觉信息太多,可以查看简洁log版本 输入 git log --pretty=oneline

简洁版log信息

看到一大串类似 6aef622c4……8445f2429f的用16进制表示的字符串是每次 commit 的ID版本号,此时我们进行版本回滚操作
选择ID的前几位字符串就足够表示版本的唯一性,输入命令 git reset --hard 6aef62

版本回滚
查看本地文件恢复情况

四、如果删除操作已经推送到了远程github服务器中,可以通过 git push 操作来进行推送

推送到远程服务器

服务器刷新前的状态

服务器刷新前的状态

刷新服务器

刷新服务器后的状态

可以看到文件被从服务器中删除了,如果此时进行文件恢复操作就需要像上面第三步那样进行版本回滚操作
当然了,这个版本回滚是在本地进行的,然后把回滚后的版本提交

git版本回滚

把回滚后的版本提交到远程服务器 git push

版本提交出错

可以看到提交出错,因为git默认是高版本覆盖低版本,但不能反过来操作,因为回滚的版本比服务器此时的版本低,所以此时常规手段是无效的,但可以进行版本的暴力提交——force
通过git的提示 git push -h 可以查看到 force的说明

查看force的解释

进行暴力提交 git push -f

暴力提交

刷新github远程服务器刷新操作

文件失而复得

如果要在服务器中回到删除文件的高级git版本版本该怎么操作呢?

  1. 当然了,最简单的办法就是把费了老劲恢复的文件再次删除就可以,这样效果上是可以的,但是之前的那个git版本号其实是丢失了。
  2. git中有一个命令 reflog 可以查看每次提交的信息,包括 commit ID和名称,可以通过提交信息找到之前的版本好,然后重新回滚就可以了。
查找commit ID

进行回滚操作

版本回滚成功

然后再进行暴力提交

暴力提交

刷新github服务器

刷新服务器

推荐阅读更多精彩内容

  • 一、Git工作流程 以上包括一些简单而常用的命令,但是先不关心这些,先来了解下面这4个专有名词。 Workspac...
    码农老K阅读 9,505评论 2 45
  • 本片内容转自CSDN http://blog.csdn.net/ithomer/article/details/7...
    五娃儿阅读 4,204评论 2 88
  • 我是一条鱼 只有七秒记忆 在梦想与现实间游离 呆在这四方空间里 忘了时间的交替 我想成为你...
    木子心韵阅读 177评论 6 1
  • 二、学习成长进步录(通过联想与联结) 昨日我从【人-事-网-书-影-音】中学习了什么?模型:本文说了什么概念?在哪...
    员子圆梦阅读 60评论 0 0
  • 有人说,你这么“宅”,不好吧? 也有人说,真羡慕你“宅”啊,像我,一天不出门一天不说话一个人在屋里呆上一天就好像生...
    不辞而别的秋天阅读 164评论 2 11