git使用revert撤销已提交的远程合并

使用背景

目前这家公司有 devtest两个分支。

我接到新需求,于是建了新的业务分支 branch1。因为需要和前端联调需要把接口发布到开发环境,然后就把 branch1 的分支合并到 dev 分支。并且 push 到仓库了。

可是,据了解,另外一个高级同事说他也在dev开发,可是联调在test。。。导致test环境会因为没有新需求相关表而报错。

解决办法

如果您需要撤销已经合并到远程分支的提交,可以考虑以下步骤:

  1. 首先使用 git log 查看要回滚的提交记录,找到需要回滚的 commit id。
*   c0416c40 (origin/dev) Merge branch 'xxx_20230730' into dev
|\
| * 67464d72 (origin/xxx_20230730, xxx_20230730) [update] xxx
| * 309fb501 [feature] xxx
| * efb6c81a [feature] xxx
| * 7cd1c383 [feature] xxx

commit id = c0416c40

  1. 然后使用 git revert 命令回滚合并提交,如下所示:
git revert -m 1 c0416c40

其中 -m 1 用于指定要回滚的提交是主分支(master)的一次合并提交。

我是将含有 Merge branch 字眼的提交分支撤销了,也就是c0416c40。这个操作会删除该提交分支提交的相关文件

  1. 完成上述步骤后,使用 git push 命令将回滚操作推送到远程分支上。注意,此处可能需要使用强制推送选项 -f,具体命令为:
git push -f origin <branch-name>

其中 <branch-name> 是您想要回滚的远程分支的名称。

  1. 最后,通知其他开发者关于您对远程分支进行了撤销操作的更改,以便他们在本地分支上拉取最新更改。

结果就是提交历史会增加一行说明

* dabb039c (HEAD -> dev) Revert "Merge branch 'xxx_20230730' into dev"
Git 中,`git revert` 是一种用于撤销已有提交的命令。当面对普通的提交(常规 commit)时,直接使用 `git revert <commit-id>` 即可完成撤销操作;然而,对于合并提交(merge commit),情况会更加复杂一些,因为一个 merge 提交具有两个或多个父提交(parents)[^3]。 ### 原理 - **Merge Commit 的特殊性**:与普通提交不同,merge commit 具有两个父提交,分别代表合并操作中涉及的两个分支的历史记录。当你执行 `git merge` 后,Git 会创建一个新的 merge commit 来表示两个分支的合并结果 [^2]。 - **Revert 的工作方式**:`git revert` 并不会修改历史提交,而是通过创建新的提交来“抵消”指定提交的影响。在撤销 merge commit 时,你需要明确告诉 Git撤销哪一条分支上的更改,即选择要保留的“主线”,而撤销另一条分支引入的变更 [^4]。 ### 操作步骤详解 1. **查找目标 merge commit 的哈希值** 使用 `git log --oneline` 查看提交历史,找到你想撤销的 merge commit 的哈希值。 2. **执行 revert 命令并指定 parent 编号** 因为 merge commit 有两个父提交Git 需要知道你希望保留哪条分支的内容作为主线。语法如下: ```bash git revert -m <parent-number> <merge-commit-hash> ``` - `<parent-number>` 可以是 `1` 或 `2`,分别代表第一个和第二个父提交- 如果你希望保留主分支(通常是合并操作中你当前所在的分支)的内容,则选择 `-m 1`;如果你希望保留被合并进来的分支内容,则选择 `-m 2` 。 3. **解决冲突(如有)** 在某些情况下,撤销 merge 提交可能会导致冲突,特别是在合并后又进行了修改的情况下。此时需要手动解决冲突,并标记文件为已解决: ```bash git add <resolved-file> ``` 4. **完成 revert 提交** Git 会自动生成一个新的提交,表示撤销了该 merge commit 所带来的更改。你可以使用默认的提交信息,也可以通过编辑器进行修改。 5. **推送更改到远程仓库(如需)** 如果你已经将 merge commit 推送到远程仓库,并且希望远程仓库也反映这一撤销操作,则需要将 revert 提交推送到远程: ```bash git push origin <branch-name> ``` ### 示例 假设你有一个 merge commit 的哈希值为 `abc1234`,并且你想撤销它,同时保留主分支的内容(即第一个父提交),则命令如下: ```bash git revert -m 1 abc1234 ``` 这将创建一个新的提交,该提交撤销 `abc1234` 这个 merge commit 引入的所有更改,但保留主分支的历史状态。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值