1. 撤销已经提交到本地仓库的 Commit
使用 git reset --<cmd-type> <commit id>
命令即可撤销已经执行的 Commit 提交记录
使用的命令及参数:
其中的 <cmd-type> 参数为你需要执行的命令,这里有三种:
- soft:该命令会保留你已经执行的 Commit 中所做出的 Changes 并 Stage
- mixed:该命令会保留你已经执行的 Commit 中所做出的 Changes 并 Unstage
- hard:该命令不会保留你已经执行的 Commit 中所做出的 Changes
即:
git reset --soft <commit id>
git reset --mixed <commit id>
git reset --hard <commit id>
其中的 <commit id> 参数为你已经执行的 Commit id,或者说你想要撤销到的某条 Commit 记录的 id:
- 当你需要撤销的只是上一步已经执行的 Commit 时,你可以使用
HEAD~1
- 当你需要撤销的那个 Commit 之后又有几条新的 Commit 记录,而你需要撤销到指定的某一条 Commit 提交记录,这时使用的是想要撤销到的那条 Commit 记录的 id
举例:
git reset --mixed HEAD~1
该命令会撤销你上一条的 Commit 记录,即回到上一次的 Commit 提交记录
git reset --mixed a5c1881
该命令会撤销 a5c1881 这个 Commit id 之后的所有 Commit 提交记录,回到 a5c1881 该条 Commit 提交记录的节点
上述命令选取的是
mixed
,第一条命令执行后会保留上一步已经执行的 Commit 中所做出的 Changes 并 Unstage;第二条命令执行后也会保留前面执行过的 Commit 中所做的 Changes,但是会把所有撤销的 Commit 的 Chages 合为一条记录
注:撤销提交记录不能跨分支撤销,否则会出错,执行撤销操作时需要注意你当前处于哪个分支节点 !
2. 撤销已经 Push 至云端的 Commit(Amend)
撤销的步骤和上面的 撤销已经提交到本地仓库的 Commit 的步骤一样,只是在最后需要执行 Force push
(强制 Push) 以消除之前 Push 的 Commit 记录
在执行过程中,可以使用( git log / git status / git reflog ) 等命令来查看相关提示信息 !