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>

其中 是您想要回滚的远程分支的名称。

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

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

* dabb039c (HEAD -> dev) Revert "Merge branch 'xxx_20230730' into dev"

你可能感兴趣的:(git)