IDEA 撤销 merge 操作(详解)

作为一个开发者,我们都知道Git是一个非常重要的版本控制工具,尤其是在协作开发的过程中。然而,在使用Git的过程中难免会踩一些坑,今天我来给大家分享一个我曾经遇到的问题:在使用IDEA中进行merge操作后如何撤销错误的合并?Abort Merge:放弃合并 对于未解决的冲突和已合并的都能回退吗? idea中merge 代码产生冲突,冲突还没解决完或者还没解决(这两种都是处于Merging的状态),这种又怎么回退?

一、前言

现在有两个本地分支dev 和 master, 将 dev 合并到 master 后如何撤销?(注意:以上操作还未 push 到远程分支)

需要分两种情况讨论:

  • 合并过程中未发生冲突
  • 合并过程中发生了冲突

二、解决方案 - 通过 Git Bash 命令行解决

这里通过 git bash 命令行的方式解决我们的问题,如果习惯通过 idea 进行版本控制的可以直接看第三部分的操作,附带详细的操作图片

1、合并过程中未发生冲突

方法一:通过 git reset --mixed [commit id]

// 第一步:查看日志,获取 commit id,即下面的cc65...
// 注意:找准 commit id,我们要找的是还没有合并前的 commit,这样我们就可以直接回退到这个 commit
Git命令:git log
效果如下:
commit cc65773448f8e9d54d40288c3926e8f3d6e88961 (HEAD -> master)
Author: xxxxxxxxxxx
Date:  xxxxxxxxx
// 第二步:回退到指定 commit id,并且将回退的代码全部放入到工作区中,这种方式比较保险
// 注意:此时修改过的代码以及新增的文件还在工作区
Git命令:git reset cc65773448f8e9d54d40288c3926e8f3d6e88961 
    或 git reset --mixed cc65773448f8e9d54d40288c3926e8f3d6e88961
// 第三步:恢复所有修改过的文件
// 注意:如果有新增的文件是不会清除的,需手动删除,红色的文件就是新增的
Git命令:git checkout . 或 git restore .

方法二:通过 git reset --hard [commit id]

// 第一步:查看日志,获取 commit id,即下面的cc65...
Git命令:git log
// 第二步:回退到指定 commit id,并清空工作目录及暂存区所有修改,简单来说就是你在这个 commit id 之后的所有操作都会被清除
// 注意:该操作比较危险,新手使用该命令需谨慎,请确保你已经掌握了该命令再使用
Git命令:git reset --hard cc657...

2、合并过程中发生冲突

方法一:通过 git merge --abort

// 最安全简便的方法,回到未合并前的状态
Git命令:git merge --abort

**补充说明:**执行 git merge 操作过程中想要终止合并,可以使用 git merge --abort
命令。这个命令通常用于在遇到合并冲突时放弃当前的合并尝试,并将您的仓库恢复到合并操作之前的状态 当你执行 git merge
并遇到冲突时,Git
会进入一个特殊的合并状态(Mergeing,正在合并中的状态),等待您解决冲突并完成合并。如果您决定不继续这次合并,可以使用上述命令来退出这个状态。

注意事项

使用 git merge --abort 是安全的,因为它不会影响您的工作目录或暂存区中的文件,只会取消当前正在进行的合并操作。
如果合并已经部分完成(例如,一些文件已经自动合并了,但其他文件存在冲突),git merge --abort 会撤销所有合并操作,包括那些已经自动完成的部分。 如果 git merge --abort 因某种原因无法完成,Git 将会通知您无法恢复到合并前的状态。这种情况很少见,通常只在仓库存在严重问题时发生。
在大多数情况下,当您在合并过程中遇到问题或决定取消合并时,git merge --abort 是恢复到合并前状态的最佳方式。
到此有了答案:Abort Merge:放弃合并 对于未解决的冲突和已合并的都能回退。完全回退到了操作git merge之前的代码状态

方法二:通过 git reset --mixed [commit id]

// 第一步:查看日志
Git命令:git log
// 第二步:回退到指定 commit id,并且将回退的代码全部放入到工作区中,这种方式比较保险
// 注意:此时修改过的代码以及新增的文件还在工作区
Git命令:git reset cc65...
    或 git reset --mixed cc65...
// 第三步:恢复所有修改过的文件
// 注意:如果有新增的文件是不会清除的,需手动删除,红色的文件就是新增的
Git命令:git checkout . 或 git restore .

方法三:通过 git reset --hard [commit id]

// 第一步:查看日志,获取 commit id,即下面的cc65...
Git命令:git log
// 第二步:回退到指定 commit id,并清空工作目录及暂存区所有修改,简单来说就是你在这个 commit id 之后的所有操作都会被清除
// 注意:该操作比较危险,新手使用该命令需谨慎,请确保你已经掌握了该命令再使用
Git命令:git reset --hard cc657...

三、解决方案 - 通过 IDEA 解决(附带详细的操作图)

以下是直接通过 IDEA 解决上述问题的操作流程,由于 idea 的版本可能不同,所以你看到的操作界面可能跟我不同,不过解决思路的一样的,你找到跟我对应的操作选项即可

1、合并过程中未发生冲突

方法一:通过 git reset --soft [commit id]

在这里插入图片描述
在这里插入图片描述

此时按 Ctrl + k 调出提交窗口,然后 Revert 掉这些文件就可以变回未合并前的状态,具体操作如下:

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
方法二:通过 git reset --hard [commit id]

注意:此操作比较危险,会清空回退前工作区以及暂存区的所有修改

在这里插入图片描述

2、合并过程中发生冲突

当合并发生冲突时,此时处于 Merging 的状态,如果想取消合并,可以用 git merge
–abort,这是最简单有效的方法,其他方法就不在这里演示了,具体操作如下

在这里插入图片描述
补充一个知识点:IDEA 不小心关闭了解决冲突窗口,怎么重新打开?
idea 版本不同,看到的界面可能不同,不过都差不多,只要找到这个 Resolve Conflicts 就可以
在这里插入图片描述

四、最后

以上是我总结的部分方法,但是还有很多其他的方式可以解决,比如 revert
命令,这个也可以将合并的代码去掉,不过它会生成新的提交记录,感兴趣的读者可以去了解下这个命令,希望以上内容能对你有帮助,如有错漏之处,望指正。

参考:https://blog.csdn.net/xmg_zs/article/details/128151889
https://blog.csdn.net/m0_57236802/article/details/134995437

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/950564.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

WD5105同步降压转换器:9.2V-95V宽电压输入,4.5A大电流输出,95%高效率,多重保护功能

概述 • WD5105同步降压转换器 • 封装形式:QFN-20封装 • 应用场景:适用于车载充电器、电动车仪表、电信基站电源、电源适配器等 性能特点 • 输入电压范围:9.2V至95V • 输出电流:可提供4.5A连续负载电流 • 效率:高…

【C++】B2108 图像模糊处理

博客主页: [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: C 文章目录 💯前言💯题目描述题目内容输入格式输出格式示例输入:输出: 💯题目分析问题拆解 💯我的做法代码实现代码分析 💯老师的做法…

怎么把word试题转成excel?

在教育行业、学校管理以及在线学习平台中,试题库的高效管理是一项核心任务。许多教育工作者和系统开发人员常常面临将 Word 中的试题批量导入 Excel 的需求。本文将详细介绍如何快速将试题从 Word 转换为 Excel,帮助您轻松解决繁琐的数据整理问题&#x…

minibatch时,损失如何记录

目录 minibatch时,损失如何记录 报错:UnboundLocalError: local variable coef referenced before assignment是什么回事 未溢出则不会报错,可以完整滴运行完成 indent 缩进 炫酷技能:一遍运行,一遍画图 实例1 解释…

Linux : Linux环境开发工具vim / gcc / makefile / gdb / git的使用

Linux环境开发工具的使用 一、操作系统的生态二、程序下载安装(一)程序安装方式(二)包管理器 yum / apt 运行原理 三、文本编辑器 vim(一)认识vim 下的操作模式(二)命令模式常用的快…

国产游戏崛起,燕云十六移动端1.9上线,ToDesk云电脑先开玩

游戏爱好者的利好消息出新了!网易大型武侠仙游《燕云十六声》正式官宣,移动端要在1月9日正式上线了!你期待手游版的燕云吗?不妨评论区留言说说你的看法。小编分别花了几个小时在台式机电脑和手机上都试了下,欣赏画面还…

力扣刷题:数组OJ篇(下)

大家好,这里是小编的博客频道 小编的博客:就爱学编程 很高兴在CSDN这个大家庭与大家相识,希望能在这里与大家共同进步,共同收获更好的自己!!! 目录 1.轮转数组(1)题目描述…

有序数据中插入不确定数据保证数据插入的位置顺序正确排序

解决有序数据中插入不确定数据保证数据插入的位置顺序正确排序 前言 java 数据库中存储自增id 有序的数据, 前端页面基于 id 5和 6 之间新增一条数据,在 id 6 和 7之间新增 2条,或者更复杂的场景,后台接口如何保存数据使得页面数…

python无需验证码免登录12306抢票 --selenium(2)

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 [TOC](python无需验证码免登录12306抢票 --selenium(2)) 前言 提示:这里可以添加本文要记录的大概内容: 就在刚刚我抢的票:2025年1月8日…

DNS协议漏洞利用实验_hust计算机网络安全实验

文章目录 计算机网络安全实验 DNS协议漏洞利用实验 docker使用 建立实验环境docker常用指令 一些注意事项设置本地 DNS 服务器 配置用户计算机设置本地DNS服务器在本地 DNS 服务器中建一个区域 修改主机文件(可略)netwox实施DNS的用户响应欺骗攻击netwo…

基于MP157AAA的I2C练习

练习要求: 通过I2C分别实现与芯片si7006(获取湿度、温度)和芯片ap3216(获取环境光照强度)的通讯; 1、运行效果 2、分析ap3216如何获取光照强度 2.1、需要操作的寄存器 通过分析手册,需要操作以下寄存器: 0x00:系统配置 0x0C&…

【Linux】深入理解文件系统(超详细)

目录 一.磁盘 1-1 磁盘、服务器、机柜、机房 📌补充: 📌通常网络中用高低电平,磁盘中用磁化方向来表示。以下是具体说明: 📌如果有一块磁盘要进行销毁该怎么办? 1-2 磁盘存储结构 ​编辑…

网络安全图谱以及溯源算法

​ 本文提出了一种网络攻击溯源框架&#xff0c;以及一种网络安全知识图谱&#xff0c;该图由六个部分组成&#xff0c;G <H&#xff0c;V&#xff0c;A&#xff0c;E&#xff0c;L&#xff0c;S&#xff0c;R>。 1|11.知识图 ​ 网络知识图由六个部分组成&#xff0c…

《Spring Framework实战》7:4.1.2.容器概述

欢迎观看《Spring Framework实战》视频教程 容器概述 该接口表示 Spring IoC 容器&#xff0c;并负责实例化、配置和组装 bean。 容器在组件上获取其指令&#xff0c;以实例化、配置和 通过读取配置元数据进行汇编。可以表示配置元数据 作为带注释的组件类、具有工厂方法的配置…

学生公寓技术规格书如何编写?

学生公寓限电柜的技术规格书主要包括以下内容‌&#xff1a; ‌用电计量计费‌&#xff1a;限电柜可以通过计算机售电管理系统进行用电计量计费&#xff0c;学生需要预交电费&#xff0c;系统会自动将数据传给控电柜和配电箱&#xff0c;对宿舍的电量进行累减计量‌。 ‌时间控…

【HarmonyOS NEXT】鸿蒙应用点9图的处理(draw9patch)

【HarmonyOS NEXT】鸿蒙应用点9图的处理&#xff08;draw9patch&#xff09; 一、前言&#xff1a; 首先在鸿蒙中是不支持安卓 .9图的图片直接使用。只有类似拉伸的处理方案&#xff0c;鸿蒙提供的Image组件有与点九图相同功能的API设置。 可以通过设置resizable属性来设置R…

SpringBoot 使用 Cache 集成 Redis做缓存保姆教程

1. 项目背景 Spring Cache是Spring框架提供的一个缓存抽象层&#xff0c;它简化了缓存的使用和管理。Spring Cache默认使用服务器内存&#xff0c;并无法控制缓存时长&#xff0c;查找缓存中的数据比较麻烦。 因此Spring Cache支持将缓存数据集成到各种缓存中间件中。本文已常…

MySQL事件功能简介

MySQL 的事件调度器&#xff08;Event Scheduler&#xff09;提供了一种便捷的方法来定时执行 SQL 语句&#xff0c;从而实现数据维护、报告生成等自动化操作。本文将详细介绍 MySQL 的事件功能&#xff0c;并说明如何使用 Navicat 管理这些事件。 1. 什么是 MySQL 事件调度器…

高光谱相机的特点

光谱特性 高光谱分辨率&#xff1a;能将光谱范围分割成极窄的波段&#xff0c;光谱分辨率通常达到纳米级甚至亚纳米级&#xff0c;可精确捕捉到不同物质在细微光谱差异上的特征&#xff0c;比如可以区分不同种类的植被因叶绿素含量等差异而在光谱上的细微变化。 多波段探测&a…

备考蓝桥杯:数据结构概念浅谈

目录 1数据结构的概念 什么是数据结构: 为什么要有数据结构 2.数据结构的三个组成要素 1.逻辑结构 2.存储结构 3.数据运算 3。算法好坏的度量&#xff08;时间复杂度和空间复杂度&#xff09; 时间复杂度计算 最优和平均和最差时间复杂度 计算时间复杂度例子 空间复…