git merge某分支到目标分支上,发现冲突太多合并代码出问题了想要回退这次提交怎么办?

1.未commit,未push

方式1: 利用idea 的可视化操作 rollback,然后删除Unversioned File即可

方式2:idea切换到其他分支,再切回来会提示这个分支有东西没有commit,让你选择commit还是drop commit,选择删除就行了

方式3:git reset --hard HEAD 回退到头结点,丢弃所有改动

2.已提交,未push

此时只需要改本地分支上的提交就行了

方式1: git reset --head HEAD^

方式2: git revert 撤回此次提交

方式3: 删除本地分支,然后从远程重新检出分支(可能会丢失一些无需丢弃的)

常见的git reset可以查看菜鸟教程
git reset 命令 | 菜鸟教程

3.已提交,已push

方式1:

git log 查看提交记录,选择回退到的commitId

git reset --hard   *******(*是commitId)

git reset 强制回退干脆利落,直接设置头结点丢弃记录,可能导致代码丢失

git reset执行完成需要push到强制远程才能生效,否则只有本地改了,IDEA可视化push操作如果不行请勾选强制推送选项

git push --force orign (强制推送可能会导致代码覆盖)

方式2:

命令行:git revert *******(*是commitId)

IDEA GIT可视化界面:选择此次提交右键git revert 

git revert回滚会保留旧的提交记录,生成一条回退记录,是不错的选择,但是在多分支并行开发的模式下会导致有些commit和并无效

例如 :feature/1   test  master三个分支

feature/1合并到test,然后git revert,

test 合并到master,然后feature/1合并到master上你会发现master缺少feature/1的提交,因为test的撤回导致了失效

Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐