git 如何撤销已经 push 的 merge

今天在合并代码时, 发现自己失误把另外一个分支 B 的代码合并到了自己分支 C, 于是想到要撤销这次 merge

一般地, 如果我们想要撤销某次 commit 可以 git revert <commit-id>. 然而, 对于 merge 类型的 commit 不能直接 git revert <commit-id>

这里举个例子:

我们错误地把 master 合并到 feature/2022-03-02-revert, 目前想要撤销这次 merge

正确的做法如下:

  1. 确保当前处于需要撤销合并的那个分支 feature/2022-03-02-revert
  2. git log -1 找到这次 merge 的 commit-id
  1. git revert 94a525c2 -m 1 这里 -m 1 表示以我们当前的所处分支 feature/2022-03-02-revert 为主线分支

  2. shift zz 保存

参考文章:

里面有未push的情况下,如何处理撤销merge操作

Git如何撤销merge操作_git 取消merge-CSDN博客

相关推荐
你的人类朋友2 小时前
✍️记录自己的git分支管理实践
前端·git·后端
wVelpro5 小时前
git diff 输出空,但 git status 提示 Motified(M)解决办法
git
high20115 小时前
【Git】-- Rebase 减少 Commit 次数指南
大数据·git·elasticsearch
曾帅1685 小时前
git报错解决
git
Murphy_lx5 小时前
团队开发者git仓库工作手册
git·团队开发
FnTop6 小时前
实用教程:打造支持参数配置的 Git Bash 文件清理脚本
开发语言·git·bash
逛逛GitHub12 小时前
GitHub 上的 3 个 AI 信息差利器,太绝了啊。
git·github
dnpao1 天前
告别密码和防火墙——将 Git 仓库从 HTTPS 切换到 SSH 连接
git·https·ssh
茜子.Java1 天前
Git 入门教程
git
winner88811 天前
Git 中 behind 和 ahead of 含义详解:分支同步状态一眼看透
git·behind·ahead of