撤回git commit操作
git commit 操作后,我们想撤回,该如何操作呢?
你可以执行以下操作:
# 仅撤回commit操作,代码依然保留。
git reset --soft HEAD^
# HEAD^表示上一个版本,也可以写成HEAD~1,HEAD~2表示撤回两次commit
git reset --soft HEAD~2
git reset 参数说明
# git reset后可以跟的参数
git reset [ --soft | --mixed [-N] | --hard | --merge | --keep] [-q] [<commit>]
# --mixed 表示不删除工作空间改动代码,撤销commit,并且撤销git add . 操作。
# 这个为默认参数,git reset --mixed HEAD^ 和 git reset HEAD^ 效果是一样的
git reset --mixed HEAD^
git reset HEAD^
# --soft 表示不删除工作空间改动代码,撤销commit,不撤销git add .
git reset --soft HEAD^
# --hard 表示删除工作空间改动代码,撤销commit,撤销git add .
git reset --hard HEAD^
# --merge --keep 一般应用于撤销git pull产生的修改
注意:
在windows的cmd控制台下操作git,想要回滚到上一次提交,但是输入git reset --hard HEAD^
后就显示more?多次回车后报错,该怎么解决呢?
解决方式如下:
# 方法一:加引号
git reset --hard "HEAD^"
# 方法二:加一个^:
git reset --hard HEAD^^
# 方法三:^换成~
git reset --hard HEAD~
git reset --hard HEAD~1
# 终极方法:换成git bash,powershell等就不会出现这种问题了
注意:
如果commit注释写错,只是想改一下注释
# 执行此命令后会默认进入vim编辑器,修改注释完毕后保存就好了。
git commit --amend