git怎么取消commit

git取消commit的方法:1、利用“git rm”命令撤銷;2、利用“git reset”命令撤銷;3、利用“git rebase”命令撤銷;4、利用“git revert”命令撤銷。

git怎么取消commit

本教程操作環境:Windows7系統、Git2.30.0版、Dell G3電腦。

有時我們提交了錯誤的代碼,需要撤銷某次的 commit 記錄,下面介紹幾種方法:

一、刪除文件

如果需要刪除的 commit 是一個或多個文件,可以進行以下操作。

1、被提交到倉庫的某個文件需要刪除,可以使用 git rm 命令:

git rm <file> // 從工作區和暫存區刪除某個文件 git commit -m "" // 再次提交到倉庫

2、如果只想從暫存區刪除文件,本地工作區不做出改變,可以:

git rm --cached <file>

3、如果在工作區不小心刪錯了某個文件,可以用 git checkout 將暫存區的文件覆蓋工作區的文件,從而把誤刪的文件恢復:

git checkout -- <file>

4、用 git rm 刪除文件,同時還會將這個刪除操作記錄下來;

用 rm 刪除文件,刪除的僅僅是本地物理文件,沒有將其從 git 的記錄中剔除。

5、git add 和 git rm 有相似的功能,

但 git add 僅能記錄添加、改動的動作,刪除的動作需靠 git rm 來完成。

二、github 撤銷某次 commit

如果需要刪除的不只是某個文件,而是交錯的代碼,那么有以下三種方法可以刪除 commit 。

1、git reset

  • git reset :回滾到某次提交。
  • git reset –soft:此次提交之后的修改會被退回到暫存區。
  • git reset –hard:此次提交之后的修改不做任何保留,git status 查看工作區是沒有記錄的。

1)回滾代碼

如果需要刪除的 commit 是最新的,那么可以通過 git reset 命令將代碼回滾到之前某次提交的狀態,但一定要將現有的代碼做好備份,否則回滾之后這些變動都會消失。具體操作如下:

git log // 查詢要回滾的 commit_id git reset --hard commit_id // HEAD 就會指向此次的提交記錄 git push origin HEAD --force // 強制推送到遠端

2)誤刪恢復

如果回滾代碼之后發現復制錯了 commit_id,或者誤刪了某次 commit 記錄,也可以通過下方代碼恢復:

git relog // 復制要恢復操作的前面的 hash 值 git reset --hard hash // 將 hash 換成要恢復的歷史記錄的 hash 值
  1. 注意:刪除中間某次提交時最好不要用 git reset 回退遠程庫,因為之后其他人提交代碼時用 git pull 也會把自己的本地倉庫回退到之前的版本,容易出現差錯進而增加不必要的工作量。

2、git rebase

  • git rebase:當兩個分支不在一條線上,需要執行 merge 操作時使用該命令。

1)撤銷提交

如果中間的某次 commit 需要刪除,可以通過 git rebase 命令實現,方法如下:

git log // 查找要刪除的前一次提交的 commit_id git rebase -i commit_id // 將 commit_id 替換成復制的值 進入 Vim 編輯模式,將要刪除的 commit 前面的 `pick` 改成 `drop` 保存并退出 Vim

這樣就完成了。

2)解決沖突

該命令執行時極有可能出現 reabase 沖突,可以通過以下方法解決:

git diff // 查看沖突內容 // 手動解決沖突(沖突位置已在文件中標明) git add <file> 或 git add -A // 添加 git rebase --continue // 繼續 rebase // 若還在 rebase 狀態,則重復 2、3、4,直至 rebase 完成出現 applying 字樣 git push

3、git revert

  • git revert:放棄某次提交。
    git revert 之前的提交仍會保留在 git log 中,而此次撤銷會做為一次新的提交。
  • git revert -m:用于對 merge 節點的操作,-m 指定具體某個提交點。

1)撤銷提交

要撤銷中間某次提交時,使用 git revert 也是一個很好的選擇:

git log // 查找需要撤銷的 commit_id git revert commit_id  // 撤銷這次提交

2)撤銷 merge 節點提交

如果這次提交是 merge 節點的話,則需要加上 -m 指令:

git revert commit_id -m 1 // 第一個提交點 // 手動解決沖突 git add -A git commit -m "" git revert commit_id -m 2 // 第二個提交點 // 重復 2,3,4 git push

推薦學習:《Git教程

以上就是

? 版權聲明
THE END
喜歡就支持一下吧
點贊12 分享