idea中git远程版本回退

工作中我们总会遇到代码版本回退的问题,下面是我所总结的方法:

1)在show history 中找到当前版本(取名:newVersion)和想要回退到的版本(oldVersion)

2. 选择newVersion和oldVersion点击“Copy Revision Number”复制两个版本的版本号:
newVersion:2746f428a3d3d000bd1b0e886ef8167e1f73ec9c
oldVersion :6bc5691cbe7304cb185b70fbc0dd975c7de86e8a

3. 右击项目依次选中:Git->Repository->Reset HEAD

4. 选中Reset Type:*Hard, To Commit:6bc5691cbe7304cb185b70fbc0dd975c7de86e8a;然后点击Reset按钮

(这一步操作相当于项目下执行命令行git reset --hard {oldVersion})

5. 这时本地代码已经回退到oldVersion,这时候如果直接push到远程仓库,会提示版本冲突,点击“cancel”取消。

 

 6. 下面有两种解决冲突的方法 
方法一 :不解决,直接强制提交: 
a. 打开Terminal,切换到项目所在目录 
b. 执行:spring-mvc $git push -f 

 方法二: 
a. 右击项目依次选中:Git->Repository->Reset HEAD 
b. 选中Reset Type:Mixed, To Commit:2746f428a3d3d000bd1b0e886ef8167e1f73ec9c;然后点击Reset按钮 

 c. 这时你会发现,最新版本有回到newVersion。但是代码还是oldVersion的代码,这时候重push到远程仓库就不会版本冲突了 
7. 方法一vs方法二 
方法一会将回退的提交记录抹点,而方法二会保留 
8. 如果想将回退的版本恢复,命令行

$gitreflog(查看记录版本号)

$git reset --hard {newVersion}

查看本地 代码已经恢复为最新版本,然后push本地最新版本到远端

原文地址:https://www.cnblogs.com/chcha1/p/12588793.html