git 删除文件

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

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

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

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

git 删除文件_第1张图片
选择要删除的文件12.md

git 删除文件_第2张图片
删除本地文件12.md

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

git 删除文件_第3张图片
恢复文件

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

git 删除文件_第4张图片
删除本地文件

通过git status查看状态


git 删除文件_第5张图片
查看删除状态

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


git 删除文件_第6张图片
添加到暂存区

查看状态,可以知道删除操作已经被添加到了暂存区,
git 删除文件_第7张图片
查看添加状态

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

git 删除文件_第9张图片
恢复文件

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

git 删除文件_第10张图片
提交删除操作

查看状态 git status

git 删除文件_第11张图片
查看删除状态

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

git 删除文件_第12张图片
查看git库版本

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

git 删除文件_第13张图片
简洁版log信息

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

git 删除文件_第14张图片
版本回滚
git 删除文件_第15张图片
查看本地文件恢复情况

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

git 删除文件_第16张图片
推送到远程服务器

服务器刷新前的状态

git 删除文件_第17张图片
服务器刷新前的状态

刷新服务器

git 删除文件_第18张图片
刷新服务器后的状态

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

git 删除文件_第19张图片
git版本回滚

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

git 删除文件_第20张图片
版本提交出错

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

git 删除文件_第21张图片
查看force的解释

进行暴力提交 git push -f

git 删除文件_第22张图片
暴力提交

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

git 删除文件_第23张图片
文件失而复得

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

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

进行回滚操作

git 删除文件_第25张图片
版本回滚成功

然后再进行暴力提交

git 删除文件_第26张图片
暴力提交

刷新github服务器

git 删除文件_第27张图片
刷新服务器

你可能感兴趣的:(git 删除文件)