已经push到远端之后,想要删除commit,并且保存之前修改
1.git log获取commit信息
2.git reset (commit-id) (想要回退的那个位置的commit id)
3.git push origin 分支名 --force
删除本地的分支
git branch -D [branchname]
删除远程未合并的分支
git push origin --delete [branchname]
在没有进行push之前可以采用如下方法进行commit的撤销
–mixed
git reset HEAD^
不删除工作空间提交的代码,撤销 commit,并且撤销 git add . 操作。
注意:-mixed 为默认参数。git reset --mixed HEAD^ 和 git reset HEAD^ 效果是一样的。
–soft
git reset --soft HEAD^
不删除工作空间提交的代码,撤销 commit,但不撤销 git add . 操作。
注意:就是说仅仅是撤回提交,修改的代码仍然保留在本地仓库。
–hard
git reset --hard HEAD^
删除工作空间提交的代码,撤销 commit,并且撤销 git add . 操作。op
注意:就是说即撤回后,本地提交的代码也不保留。就等于恢复到了上一次的 commit 状态。
本文介绍了在已push到远端后如何删除git commit。通过git log获取commit信息,使用git reset (commit-id)回退到指定位置,再用git push --force更新远端。在未push前,可通过--mixed、--soft、--hard三种方式撤销commit,它们分别有不同的工作空间保留策略。
6561

被折叠的 条评论
为什么被折叠?



