一、问题描述
在使用idea操作项目中,错误删除了项目的部分类,本来想简单通过revert实现删除恢复。但是,却无法恢复,提示
提示如下,文件无法恢复
二、问题原因
在idea是无法看到原因了,因为idea封装了git的命令。所以,直接进入项目.git目录,使用git status查看真正原因
$ git status
On branch master
Your branch is up-to-date with ‘origin/master’.
Changes to be committed:
(use “git reset HEAD …” to unstage)
deleted: mybatis-06/src/main/java/com/rui/dao/TeacherMapper.java
deleted: mybatis-06/src/main/java/com/rui/pojo/Student.java
deleted: mybatis-06/src/main/java/com/rui/pojo/Teacher.java
deleted: mybatis-06/src/main/java/com/rui/utils/MyBatisUtils.java
deleted: mybatis-06/src/main/resources/com/rui/dao/StudentMapper.xml
deleted: mybatis-06/src/main/resources/com/rui/dao/TeacherMapper.xml
Changes not staged for commit:
(use “git add/rm …” to update what will be committed)
(use “git checkout – …” to discard changes in working directory)
modified: mybatis-01/target/classes/com/rui/dao/UserMapper.xml
modified: mybatis-01/target/classes/mybatis-config.xml
modified: mybatis-02/target/classes/mybatis-config.xml
modified: mybatis-03/target/classes/com/rui/dao/UserMapper.xml
deleted: mybatis-06/src/main/java/com/rui/dao/StudentMapper.java
modified: mybatis-07/target/classes/com/rui/dao/StudentMapper.class
modified: mybatis-07/target/classes/com/rui/dao/TeacherMapper.class
modified: mybatis-07/target/classes/com/rui/dao/TeacherMapper.xml
modified: mybatis-07/target/classes/com/rui/pojo/Student.class
modified: mybatis-07/target/classes/com/rui/pojo/Teacher.class
modified: mybatis-07/target/classes/com/rui/utils/MyBatisUtils.class
modified: mybatis-07/target/classes/db.properties
modified: mybatis-07/target/test-classes/com/rui/MyTest.class
modified: “mybatis\347\254\224\350\256\260/Mybatis\347\254\224\350\256\260.md”
Untracked files:
(use “git add …” to include in what will be committed)
.idea/
MyBatis-Study.iml
mybatis-01/mybatis-01.iml
mybatis-02/mybatis-02.iml
mybatis-03/mybatis-03.iml
mybatis-04/log/log4j-DEBUG.log
…
原因很清楚,按照提示进行reset和checkout操作即可。具体原因,git的工作区-暂存区-本地仓库和远程仓库四者的关系已经很清楚,如下图
三、解决方法
1.打开git bash,这个才是底层。
2.进入需要恢复目录,运行reset命令
$ git reset .
Unstaged changes after reset:
D mybatis-06/src/main/java/com/rui/dao/TeacherMapper.java
D mybatis-06/src/main/java/com/rui/pojo/Student.java
D mybatis-06/src/main/java/com/rui/pojo/Teacher.java
D mybatis-06/src/main/java/com/rui/utils/MyBatisUtils.java
D mybatis-06/src/main/resources/com/rui/dao/StudentMapper.xml
D mybatis-06/src/main/resources/com/rui/dao/TeacherMapper.xml
3.运行checkout
$ git checkout .
即可恢复
四、总结
D mybatis-06/src/main/resources/com/rui/dao/TeacherMapper.xml
3.运行checkout
```ruby
$ git checkout .
即可恢复
四、总结
1.idea是方便,但是必要的时候,还是需要理解底层git操作逻辑。