IntelliJ Idea 撤回git已经push的操作

最初的样子

现在的样子

解决方案

第一步,commit到本地撤回:

打开提交历史记录,选中回退的版本右键,点击"Reset Current Branch to Here...",然后选中"Mixed",点击Reset后,之前commit的代码会在本地显示未提交的。修改之后继续正常提交即可。

第二步,push到远程仓库的撤回

需要idea和git指令配合使用,

  1. 选中要回退到分支,右键"Copy Revision Number",

  2. 然后调出"Reset Head"窗口,项目名上->右击->git->Reset HEAD...,

    Reset Type :Hard

    To Commit:粘贴第一步拷贝的Revision Number

    点击reset后,之前提交的代码会丢失,需要做好本地备份,做完该操作以后远程仓库的提交记录还存在,需用git 指令强制提交到远程仓库。

  3. git push -f 强制提交

    打开项目所在位置,打开git bash here 执行"git push -f ",远程仓库的提交记录就没有了。

Notices: 可以在git上先copy一个新的branch,然后再执行以上操作,这样之前的代码也会保留。

成功

相关推荐
历程里程碑30 分钟前
2. Git版本回退全攻略:轻松掌握代码时光机
大数据·c++·git·elasticsearch·搜索引擎·github·全文检索
U盘失踪了1 小时前
Java 的 JAR 是什么?
java·jar
今天又在写代码2 小时前
java-v2
java·开发语言
competes2 小时前
慈善基金投资底层逻辑应用 顶层代码低代码配置平台开发结构方式数据存储模块
java·开发语言·数据库·windows·sql
2501_913061343 小时前
网络原理知识
java·网络
希望永不加班3 小时前
Spring AOP 代理模式:CGLIB 与 JDK 动态代理区别
java·开发语言·后端·spring·代理模式
flushmeteor4 小时前
java的动态代理和字节码生成技术
java·动态代理·代理·字节码生成
eggwyw4 小时前
基于SpringBoot和PostGIS的云南与缅甸的千里边境线实战
java·spring boot·spring
0xDevNull4 小时前
MySQL 别名(Alias)指南:从入门到避坑
java·数据库·sql
lv__pf4 小时前
springboot原理
java·spring boot·后端