赞
踩
场景:
假设你有一个A分支
,现在A分支
merge 到master分支
上了,你想撤销A分支
的merge,将master分支
回退到A分支
merge之前的状态
先切换到A分支
上,再从A分支上新建一个分支
,这个分支用来回退代码
git checkout -b revert-merge-branch
比如我现在在A分支
上切出一个名叫revert-merge-branch的分支
git revert -m 1 <merge提交的SHA>
比如 我这里就要写 git revert -m 1 e68fefb46c5ecddcbc92e05c90831cbc65024790
此时你的 revert-merge-branch分支
就是已经回退到 merge 的分支了,再将这个分支merge到master分支上,并将master分支推向远端,就完成了撤销提交。
这样操作导致的一个问题,如果想将A分支再次merge到master分支上,会发现A分支无法merge了
原因:git依据提交记录确定哪些改动哪些没改,不会对比两个分支的代码结构
解决步骤:
1.git checkout master
切换到最新的master分支上
2.git log
找到当时撤销A分支merge的commit ID
3.
git checkout A分支
切换到A分支上
4. 将master分支merge到A分支上(这一步你会发现你A分支上的写的代码都没了,被master覆盖掉了,没事,后续步骤会找回来)
5.git revert -n revertID
将revert的版本再revert一下
6. 此时当前分支就可以随便merge了
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。