git撤銷commit 並保存以前的修改

撤銷並保留修改

參數 –soft

  1.   # 先進行commit ,以後後悔啦
  2.  $ git commit -am "對首篇報告研究員字段改成author_name"

執行git logjava

  1.  $ git log
  2.   
  3.   commit 3d6788f577faba5e1d408e372031c81beee79749
  4.  Author: yous <yous.com>
  5.   Date: Thu Dec 14 10:08:36 2017 +0800
  6.  
  7.  添加
  8.   
  9.   commit 5029f0cc08cffb77f7358de7d5534e8f8eacb82e
  10.  Author: yous <yous.com>
  11.   Date: Thu Dec 14 09:52:39 2017 +0800
  12.  
  13.  Revert "Revert "修改過程""
  14.   
  15.  This reverts commit c81f785a06804f5f40b41dedd038efbe6d83f8a8.
  16.   
  17.   commit c81f785a06804f5f40b41dedd038efbe6d83f8a8
  18.  Author: yous <yous.com>
  19.   Date: Thu Dec 14 09:52:22 2017 +0800
  20.   
  21.  Revert "修改"
  22.   
  23.  This reverts commit 5a1d18a032d8c9269613ff14593847f82043e627.
  24.   
  25.   commit 5a1d18a032d8c9269613ff14593847f82043e627

能夠看出,第一個是我剛剛commit的,我要撤銷,固然是選擇第二個;git

執行命令git reset --soft <commit>sql

$ git reset --soft 5029f0cc08cf
  •  以後咱們查看下,狀態:
  1.  $ git status
  2.   On branch yutao
  3.  Your branch is up-to-date with 'origin/yutao'.
  4.  Changes to be committed:
  5.  (use "git reset HEAD <file>..." to unstage)
  6.   
  7.  modified: dataservice/app/ggservice/v1/ event/service/InfoEventService.java

能夠看出已經回撤啦,而且保留了修改。緩存

參數 –mixed

  1.  $ git reset --mixed 5029f0cc08cff
  2.  Unstaged changes after reset:
  3.  M dataservice/app/ggservice/v1/ event/service/InfoEventService.java
  4.   
  5.  yutao@yutao MINGW64 /d/sts/workspace/ggservice (yutao)
  6.  $ git status
  7.   On branch yutao
  8.  Your branch is up-to-date with 'origin/yutao'.
  9.  Changes not staged for commit:
  10.  ( use "git add <file>..." to update what will be committed)
  11.  ( use "git checkout -- <file>..." to discard changes in working directory)
  12.  
  13.  modified: dataservice/app/ggservice/v1/ event/service/InfoEventService.java
  14.   
  15.   no changes added to commit (use "git add" and/or "git commit -a")

這種方式也是能夠的。 
參數--soft--mixed區別:app

參數 區別
--soft 會將改動放在緩存區
--mixed 不把改動放在緩存區

git reset –hard <commit_id>

這種方式,我我的是不推薦,它也是撤銷,可是不會保留修改。 
除非你確實是不想要剛剛commit的內容,不然,這個操做會讓你以前乾的活,白乾。 
因此很是不推薦這個方式。ui

相關文章
相關標籤/搜索