git 撤销_git撤销commit - CSDN
精华内容
参与话题
  • Git-撤销/回滚操作

    万次阅读 2017-12-22 14:06:38
    git结构和各操作之间的关系

    git结构和各操作之间的关系

    git分层
    WorkDir进行add操作将当前修改同步到 Index,执行commit操作同步到Head,执行push上传到Server。

    撤销add操作

    撤销add
    git reset [HEAD/commitid] 使用HEAD或者commitid覆盖Index,不影响Head和WorkDir,如果是在commit之后执行这个操作相当于同时撤销了commit和add操作
    git reset [HEAD/commitid] – file 针对某个文件使用HEAD或者commitid覆盖Index,不影响Head和WorkDir

    撤销commit操作

    撤销commit
    git reset –soft HEAD^ 重置HEAD到上一版本,即撤销commit操作,不影响index和workdir。
    git reset –soft HEAD^1 ^后面的数字表示恢复到哪个父提交的版本,一个提交可能会对应多个父提交,用于指定回到哪个
    git reset –soft commitid 后面添加comiit_id指明回退到哪个版本

    撤销commit和add

    撤销commit和add
    git reset –mixed HEAD^ 效果同git reset HEAD^
    git reset –mixed HEAD^1 ^后面的数字表示恢复到哪个父提交的版本,一个提交可能会对应多个父提交,用于指定回到哪个

    撤销commit、add操作,并将本地版本也重置为上一版本

    撤销commit、add并重置本地
    git reset –hard HEAD^ 重置head到上一版本,会覆盖index, –hard会使head、index、workdir都重置回之前的版本,远程服务器上不会变,如果希望远程服务器上也回到上一版本的话,就使用一下git push –force。
    git reset –hard HEAD^1 ^后面的数字表示恢复到哪个父提交的版本,一个提交可能会对应多个父提交,用于指定回到哪个
    git reset –hard commitid 用commit_id指定回到哪次 commit

    git revert

    git revert commitid 使用某一次提交覆盖当前,已达到恢复到某次的效果。revert之后执行一次git push同步到server。

    git reset 和 git revert 的区别

    git reset 简单暴力的将版本置回到某个版本,现在有过a、b、c、d四次提交,提交顺序为a、b、c、d,现在为d。使用git reset恢复到a之后,看git log,就只剩下a了,b、c、d都不见了。使用git revert恢复到a之后,看git log,会发现a、b、c、d都在,多了e操作,e操作为“revert a”。
    原始log:
    原始log
    执行过git reset之后:
    reset之后
    可以看到commitid为7f****的log记录已经没有了

    再来看一下revert:
    revert
    解决完冲突,revert之后:
    revert之后
    可以看到这里多了一条“Revert ‘commit add’”的记录。

    展开全文
  • git 优雅的撤销中间某次提交

    万次阅读 多人点赞 2018-06-18 22:05:17
    git : 2+ 前言 最近两天,公司的git合并代码时,出现了严重的问题,浪费很多时间; 现在记录下; 情况是这样的,一个同事自己的本地分支(远程没有),不知怎么的,有了别人开发分支的代码,而他自己又不知道...

    环境

    git : 2+

    前言

    最近两天,公司的git合并代码时,出现了严重的问题,浪费很多时间;
    现在记录下;
    情况是这样的,一个同事自己的本地分支(远程没有),不知怎么的,有了别人开发分支的代码,而他自己又不知道;
    其在切换到主分支,并merge自己的分支,此时其已经把别人正在开发的代码都合并到了主分支。

    到了晚上准备升级时,才发现,主分支的代码出了问题;此时版本库是这样的:
    这里写图片描述

    如图 100047dcc这一步就有不该有的代码;

    而此时版本库已经提交过了很多次,现在的问题就是,如何撤销掉100047dcc提交的代码,并且保留其他人提交的代码。

    这个问题,折腾到了晚上9点半左右,尝试了网上给出的:

    git rebase -i commit_id
    //再通过将pick改为drop

    但是,实际的效果是,100047dcc代码没了,其他人提交的代码也没有了!
    也就是给人感觉和git reset --hard be8c6f6dd没有什么区别!

    最后因为太晚,从提交记录上看,100047dcc之后就一个人提交了代码,所以就执行了:

    //先切一个备份分支
    git branch -b master_tmp
    //再执行
    git reset --hard be8c6f6dd

    之后,那个人(也就是我)从备份分支上把文件拷贝回来—(因为我是直接在主分支上改的,自己的分支并没有代码)。

    第二天,我打算去拷贝文件,我执行如下操作:

    yutao@yutao MINGW64 /d/sts/workspace/ggservice (master)
    $ git pull
    remote: Counting objects: 44, done.
    remote: Compressing objects: 100% (23/23), done.
    remote: Total 26 (delta 19), reused 0 (delta 0)
    Unpacking objects: 100% (26/26), done.
    From gitlab.gofund.cn:gg-service/ggservice
     + 1784b12...384decc master     -> origin/master  (forced update)
       f8f2b19..eb33489  devyaomy   -> origin/devyaomy
     * [new branch]      master_tmp -> origin/master_tmp
    Already up-to-date.
    
    yutao@yutao MINGW64 /d/sts/workspace/ggservice (master)
    $ git status
    On branch master
    Your branch is ahead of 'origin/master' by 796 commits.
      (use "git push" to publish your local commits)
    nothing to commit, working directory clean
    
    yutao@yutao MINGW64 /d/sts/workspace/ggservice (master)
    $ git push
    Total 0 (delta 0), reused 0 (delta 0)
    To git@gitlab.gofund.cn:gg-service/ggservice.git
       384decc..1784b12  master -> master

    简单的说,我的操作就是两步:
    1git pull
    2、git push
    结果又把代码还原回去了!

    为啥呢?

    虽然昨天晚上,把远程库的版本回退到了正确的版本,但是我的本地主分支还是最新的commit,也就是说,相比远程库,我本地库是超前了多次提交,毕竟因为远程库回退了嘛!

    这个时候,我必须也得对本地库进行回退,回退到线上相同的commit节点才行。

    这个时候,我做了以下几个操作:

    yutao@yutao MINGW64 /d/sts/workspace/ggservice (master)
    $ git reset --soft 384deccaa6
    $ git status
    On branch master
    Your branch is up-to-date with 'origin/master'.
    Changes to be committed:
      (use "git reset HEAD <file>..." to unstage)
    
            modified:   .gitignore
            modified:   conf/application.conf
            new file:   conf/hanlp.properties
            new file:   dataservice/app/ggservice/common/UserCodeEnum.java
            new file:   dataservice/app/ggservice/v1/email/action/BindEmailGG3Action.java
            new file:   dataservice/app/ggservice/v1/email/action/SendEmailCaptchaGG3Action.java
            // 文件太多不一一显示
    yutao@yutao MINGW64 /d/sts/workspace/ggservice (master)
    $ git reset --hard 384deccaa6

    上面敲了很多命令,其实真正只需要git reset --hard 384deccaa6即可。

    git reset --hard 384deccaa6

    接下来,我开始复制粘贴,从备份分支上,把代码拷贝下。
    真的操蛋,这等于是增加工作量啊!

    revert 撤销某次提交

    到了下午,又有个同事干了类似我上午的操作。把不该有的代码提交上去了!
    这就麻烦了,虽然远程库回退了!结果是要求凡是pull最新代码的人,都得进行本地回退的操作。
    否则,就没完没了!

    到了晚上,对着备份分支进行测试,终于找到了优雅的解决办法!

    这就是revert命令

    该命令就是为撤销某次提交而存在的;

    首先,我是明白100047dcc这次提交是有问题的,这是问题的源头;
    也就是说,只要我们把这次提交的给撤销了,就不会有问题了!

    步骤 一

    $ git revert 100047dcc
    error: Commit 100047dccb58f3ee5e27b0dfaf5c02ac91dc2c73 is a merge but no -m option was given.
    fatal: revert failed

    结果报错了,报了一个Commit is a merge but no -m option was given.

    为什么呢?

    如果100047dcc这只是一个普通的提交,其实是不会报错的!
    但是,这是一个merge的提交。

    那么在撤销时,git并不知道我要撤销具体哪次!如下图:
    这里写图片描述

    这个时候,怎么办呢?

    我的做法

    步骤二

    yutao@yutao MINGW64 /d/sts/workspace/ggservice (master_tmp)
    $ git revert 100047dcc -m 1
    error: could not revert 100047d... Merge branch 'master' of gitlab.gofund.cn:gg-service/ggservice into wjs
    hint: after resolving the conflicts, mark the corrected paths
    hint: with 'git add <paths>' or 'git rm <paths>'
    hint: and commit the result with 'git commit'

    我执行了这样的一个操作:

    git revert 100047dcc -m 1

    参数 -m 就是指定要撤销的那个提价,从左往右,从1开始数;也就是我撤销的是ca4a7ff999

    接着其把代码冲突,然后我就解决冲突,保留主分支的代码,去掉那个人的代码。

    解决完冲突后,我执行如下操作:

    yutao@yutao MINGW64 /d/sts/workspace/ggservice (master_tmp|REVERTING)
    $ git add -A
    
    yutao@yutao MINGW64 /d/sts/workspace/ggservice (master_tmp|REVERTING)
    $ git status
    On branch master_tmp
    Your branch is up-to-date with 'origin/master_tmp'.
    You are currently reverting commit 100047d.
      (all conflicts fixed: run "git revert --continue")
      (use "git revert --abort" to cancel the revert operation)
    
    Changes to be committed:
      (use "git reset HEAD <file>..." to unstage)
    
            modified:   dataservice/app/ggservice/v1/datacentre/action/GetIncomeDistributeAction.java
            //文件太多省略。。。
    
    yutao@yutao MINGW64 /d/sts/workspace/ggservice (master_tmp|REVERTING)
    $ git commit -m "ceshi"
    [master_tmp d2ae829] ceshi
     18 files changed, 95 insertions(+), 396 deletions(-)

    我上面执行的语句其实就是:

    $ git add -A
    $ git commit -m "ceshi"

    步骤三

    yutao@yutao MINGW64 /d/sts/workspace/ggservice (master_tmp)
    $ git revert 100047dcc -m 2
    error: could not revert 100047d... Merge branch 'master' of gitlab.gofund.cn:gg-service/ggservice into wjs
    hint: after resolving the conflicts, mark the corrected paths
    hint: with 'git add <paths>' or 'git rm <paths>'
    hint: and commit the result with 'git commit'

    也就是执行:

    $ git revert 100047dcc -m 2

    即 撤销be8c6f6dde的提交,这个时候也会提示代码冲突了,

    接着和上面一样,解决冲突,在提交:

    yutao@yutao MINGW64 /d/sts/workspace/ggservice (master_tmp|REVERTING)
    $ git status
    On branch master_tmp
    Your branch is ahead of 'origin/master_tmp' by 1 commit.
      (use "git push" to publish your local commits)
    You are currently reverting commit 100047d.
      (fix conflicts and run "git revert --continue")
      (use "git revert --abort" to cancel the revert operation)
    
    Changes to be committed:
      (use "git reset HEAD <file>..." to unstage)
    
            modified:   .gitignore
            deleted:    conf/hanlp.properties
            deleted:    dataservice/app/ggservice/common/UserCodeEnum.java
            deleted:    dataservice/app/ggservice/v1/email/action/BindEmailGG3Action.java
            deleted:    dataservice/app/ggservice/v1/email/action/SendEmailCaptchaGG3Action.java
            deleted:    dataservice/app/ggservice/v1/email/service/EmailCaptchaService.java
            deleted:    dataservice/app/ggservice/v1/expert/action/GetExpertOfStockAssessAction.java
            modified:   dataservice/app/ggservice/v1/expert/service/ExpertGG3Service.java
            modified:   dataservice/app/ggservice/v1/ggmtoolbox/action/GetMyStockLabelInfoAction.java
            modified:   dataservice/app/ggservice/v1/ggmtoolbox/action/UpdateUserTokenInfoAction.java
            modified:   dataservice/app/ggservice/v1/ggmtoolbox/service/AppDOSInfoService.java
            modified:   dataservice/app/ggservice/v1/ggmtoolbox/service/UserInfoService.java
            modified:   dataservice/app/ggservice/v1/graph/action/GetStockPlateComponentAction.java
            modified:   dataservice/app/ggservice/v1/graph/service/StockPlateService.java
            // 文件太多省略。。。
    
    yutao@yutao MINGW64 /d/sts/workspace/ggservice (master_tmp|REVERTING)
    $ git add -A
    
    yutao@yutao MINGW64 /d/sts/workspace/ggservice (master_tmp|REVERTING)
    $ git status
    On branch master_tmp
    Your branch is ahead of 'origin/master_tmp' by 1 commit.
      (use "git push" to publish your local commits)
    You are currently reverting commit 100047d.
      (all conflicts fixed: run "git revert --continue")
      (use "git revert --abort" to cancel the revert operation)
    
    Changes to be committed:
      (use "git reset HEAD <file>..." to unstage)
    
            modified:   .gitignore
            modified:   conf/application.conf
            deleted:    conf/hanlp.properties
            deleted:    dataservice/app/ggservice/common/UserCodeEnum.java
            deleted:    dataservice/app/ggservice/v1/email/action/BindEmailGG3Action.java
            deleted:    dataservice/app/ggservice/v1/email/action/SendEmailCaptchaGG3Action.java
            deleted:    dataservice/app/ggservice/v1/email/service/EmailCaptchaService.java
            deleted:    dataservice/app/ggservice/v1/expert/action/GetExpertOfStockAssessAction.java
            modified:   dataservice/app/ggservice/v1/expert/service/ExpertGG3Service.java
            modified:   dataservice/app/ggservice/v1/ggmtoolbox/action/GetMyStockLabelInfoAction.java
            modified:   dataservice/app/ggservice/v1/ggmtoolbox/action/UpdateUserTokenInfoAction.java
            modified:   dataservice/app/ggservice/v1/ggmtoolbox/service/AppDOSInfoService.java
            modified:   dataservice/app/ggservice/v1/ggmtoolbox/service/UserInfoService.java
            modified:   dataservice/app/ggservice/v1/graph/action/GetStockPlateComponentAction.java
            modified:   dataservice/app/ggservice/v1/graph/service/StockPlateService.java
            modified:   dataservice/app/ggservice/v1/hq/action/GetStockHistoryDynamicAction.java
            modified:   dataservice/app/ggservice/v1/keybordspirit/action/GetMyGroupStockIndexAction.java
    
    yutao@yutao MINGW64 /d/sts/workspace/ggservice (master_tmp|REVERTING)
    $ git commit -m "使用revert 版本号 -m 1或者2同时进行撤销某次提交测试"
    [master_tmp 236da00] 使用revert 版本号 -m 1或者2同时进行撤销某次提交测试
     95 files changed, 2093 insertions(+), 10011 deletions(-)
     delete mode 100644 conf/hanlp.properties
     delete mode 100644 dataservice/app/ggservice/common/UserCodeEnum.java
     delete mode 100644 dataservice/app/ggservice/v1/email/action/BindEmailGG3Action.java
     delete mode 100644 dataservice/app/ggservice/v1/email/action/SendEmailCaptchaGG3Action.java
     delete mode 100644 dataservice/app/ggservice/v1/email/service/EmailCaptchaService.java
     delete mode 100644 dataservice/app/ggservice/v1/expert/action/GetExpertOfStockAssessAction.java
     delete mode 100644 dataservice/app/ggservice/v1/mobile/action/BindMobileGG3Action.java
     delete mode 100644 dataservice/app/ggservice/v1/mobile/action/SendMobileCaptchaGG3Action.java
     rewrite dataservice/app/ggservice/v1/mystocktags/service/MyStockTagService.java (82%)
     delete mode 100644 dataservice/app/ggservice/v1/report/action/GetAuthorRankListAction.java
     delete mode 100644 dataservice/app/ggservice/v1/report/action/GetAuthorRecommendReportListAction.java
     delete mode 100644 dataservice/app/ggservice/v1/report/action/GetHonoraryAuthorListAction.java
     delete mode 100644 dataservice/app/ggservice/v1/report/action/GetHotIndustryListAction.java
     delete mode 100644 dataservice/app/ggservice/v1/report/action/GetHotStockListAction.java
     delete mode 100644 dataservice/app/ggservice/v1/report/action/GetHotThemeListAction.java
     delete mode 100644 dataservice/app/ggservice/v1/report/action/GetOrganRankListAction.java
     delete mode 100644 dataservice/app/ggservice/v1/report/condition/AuthorOrganRankCondition.java
     delete mode 100644 dataservice/app/ggservice/v1/report/condition/HotReportCondition.java
     delete mode 100644 dataservice/app/ggservice/v1/report/service/HotReportService.java
     delete mode 100644 dataservice/app/ggservice/v1/usergg/action/AutoLoginAction.java
     delete mode 100644 dataservice/app/ggservice/v1/usergg/action/BindOuterChannelAction.java
     delete mode 100644 dataservice/app/ggservice/v1/usergg/action/EmailRegisterAction.java
     delete mode 100644 dataservice/app/ggservice/v1/usergg/action/GetUserAction.java
     delete mode 100644 dataservice/app/ggservice/v1/usergg/action/IsAccountExistAction.java
     delete mode 100644 dataservice/app/ggservice/v1/usergg/action/LoginAction.java
     delete mode 100644 dataservice/app/ggservice/v1/usergg/action/LogoutAction.java
     delete mode 100644 dataservice/app/ggservice/v1/usergg/action/OuterChannelLoginAction.java
     delete mode 100644 dataservice/app/ggservice/v1/usergg/action/RegisterAction.java
     delete mode 100644 dataservice/app/ggservice/v1/usergg/service/LoginService.java
     delete mode 100644 dataservice/app/ggservice/v1/usergg/service/RegisterService.java
     delete mode 100644 dataservice/app/ggservice/v1/usergg/service/UserCommonUtils.java
     delete mode 100644 dataservice/app/ggservice/v1/usergg/service/UserService.java

    即:

    $ git add -A
    $ git commit -m "使用revert 版本号 -m 1或者2同时进行撤销某次提交测试"

    可以看出删除掉了那个人提交的文件。

    最后一步

    yutao@yutao MINGW64 /d/sts/workspace/ggservice (master_tmp)
    $ git push

    这样就把那个人提交错误的代码给删除了,其他人的本地分支也不需要版本回退了!
    一次改好,到处OK!

    总结

    当想撤销中间某次提交时,强烈建议使用revert命令,而不是reset
    git reset –hard commit_id 虽然可以回退远程库,但是其要求pull最新代码的每个人的本地分支都要进行版本回退。这样就增加工作量了!

    正确的步骤

    git revert commit_id
    //如果commit_id是merge节点的话,-m是指定具体哪个提交点
    git revert commit_id -m 1
    //接着就是解决冲突
    git add -A
    git commit -m ".."
    git revert commit_id -m 2
    //接着就是解决冲突
    git add -A
    git commit -m ".."
    git push

    其中git revert commit_id -m 数字是针对,merge提交点的操作。
    如果是普通的提交点,不需要这么麻烦。

    参考地址:
    [Git高级教程(二)] 远程仓库版本回退方法
    https://www.cnblogs.com/ShaYeBlog/p/5368064.html
    https://blog.csdn.net/hongchangfirst/article/details/49472913

    展开全文
  • 【Git】Git撤销add操作

    万次阅读 2019-02-01 12:23:08
    查看Git状态 $ git status On branch master Your branch is up-to-date with 'origin/master'. Changes to be committed: (use &amp;amp;quot;git reset HEAD &amp;amp;amp;lt;file&amp;amp;amp;gt;.....

    Git add错了文件怎么办?可以查看以下两篇
    https://git-scm.com/book/zh/v1/Git-基础-记录每次更新到仓库
    https://git-scm.com/book/zh/v1/Git-基础-撤消操作

    我们来实践一下

    查看Git状态

    $ git status
    On branch master
    Your branch is up-to-date with 'origin/master'.
    Changes to be committed:
      (use "git reset HEAD <file>..." to unstage)
    
            modified:   .idea/misc.xml
            modified:   .idea/modules.xml
            modified:   app/app.iml
    
    

    只要在 “Changes to be committed” 这行下面的,就说明是已暂存状态。也就是说这些文件被add过,但是没有commit。如果此时提交,那么该文件此时此刻的版本将被留存在历史记录中。
    但是这些文件是被.ignore忽略的,所以我们应该取消add

    git reset HEAD <路径/文件名> 就是对某个文件进行撤销了

    测试下

    $ git status
    On branch master
    Your branch is up-to-date with 'origin/master'.
    Changes to be committed:
      (use "git reset HEAD <file>..." to unstage)
    
            modified:   .idea/modules.xml
            modified:   app/app.iml
    
    Changes not staged for commit:
      (use "git add <file>..." to update what will be committed)
      (use "git checkout -- <file>..." to discard changes in working directory)
    
            modified:   .idea/misc.xml
    
    

    文件misc.xml 出现在 “Changes not staged for commit” 这行下面,说明已跟踪文件的内容发生了变化,但还没有放到暂存区。

    因为.idea/misc.xml已经被.ignore忽略了,所以对它的修改完全没有必要,我们看到刚才的输出界面在第二个括号中,我们看到了抛弃文件修改的命令,试一下

    $ git checkout -- .idea/misc.xml
    

    git reset HEAD 如果后面什么都不跟的话 就是上一次add 里面的全部撤销了

    $  git reset HEAD
    Unstaged changes after reset:
    M       .idea/modules.xml
    M       app/app.iml
    
    

    我们再用git checkout -- <路径/文件名>

    $ git checkout -- .idea
    

    这样就摒弃了.idea文件夹里的文件修改

    我们可以同样操作其他文件夹,最后用git status查看下状态

    $ git status
    On branch master
    Your branch is up-to-date with 'origin/master'.
    nothing to commit, working tree clean
    
    
    展开全文
  • Git撤销&回滚操作(git reset 和 get revert)

    万次阅读 多人点赞 2020-01-06 17:50:59
    git的工作流 工作区:即自己当前分支所修改的代码,git add xx 之前的!不包括 git add xx 和 git commit xxx 之后的。 暂存区:已经 git add xxx 进去,且未 git commit xxx 的。 本地分支:已经git commit -m ...

    git的工作流

    工作区:即自己当前分支所修改的代码,git add xx 之前的!不包括 git add xx 和 git commit xxx 之后的。

    暂存区:已经 git add xxx 进去,且未 git commit xxx 的。

    本地分支:已经git commit -m xxx 提交到本地分支的。
    这里写图片描述


    代码回滚

    在上传代码到远程仓库的时候,不免会出现问题,任何过程都有可能要回滚代码:

    1、在工作区的代码

    git checkout -- a.txt   # 丢弃某个文件,或者
    git checkout -- .       # 丢弃全部

    注意:git checkout – . 丢弃全部,也包括:新增的文件会被删除、删除的文件会恢复回来、修改的文件会回去。这几个前提都说的是,回到暂存区之前的样子。对之前保存在暂存区里的代码不会有任何影响。对commit提交到本地分支的代码就更没影响了。当然,如果你之前压根都没有暂存或commit,那就是回到你上次pull下来的样子了。

    2、代码git add到缓存区,并未commit提交

    git reset HEAD .  或者
    git reset HEAD a.txt

    这个命令仅改变暂存区,并不改变工作区,这意味着在无任何其他操作的情况下,工作区中的实际文件同该命令运行之前无任何变化

    3、git commit到本地分支、但没有git push到远程

    git log # 得到你需要回退一次提交的commit id
    git reset --hard <commit_id>  # 回到其中你想要的某个版
    或者
    git reset --hard HEAD^  # 回到最新的一次提交
    或者
    git reset HEAD^  # 此时代码保留,回到 git add 之前

    4、git push把修改提交到远程仓库
    1)通过git reset是直接删除指定的commit

    git log # 得到你需要回退一次提交的commit id
    git reset --hard <commit_id>
    git push origin HEAD --force # 强制提交一次,之前错误的提交就从远程仓库删除

    2)通过git revert是用一次新的commit来回滚之前的commit

    git log # 得到你需要回退一次提交的commit id
    git revert <commit_id>  # 撤销指定的版本,撤销也会作为一次提交进行保存

    3) git revert 和 git reset的区别
    - git revert是用一次新的commit来回滚之前的commit,此次提交之前的commit都会被保留;
    - git reset是回到某次提交,提交及之前的commit都会被保留,但是此commit id之后的修改都会被删除

    开发过程中,你肯定会遇到这样的场景:

    场景一:

    糟了,我刚把不想要的代码,commit到本地仓库中了,但是还没有做push操作!

    场景二:

    彻底完了,刚线上更新的代码出现问题了,需要还原这次提交的代码!

    场景三:

    刚才我发现之前的某次提交太愚蠢了,现在想要干掉它!

    撤销

    上述场景一,在未进行git push前的所有操作,都是在“本地仓库”中执行的。我们暂且将“本地仓库”的代码还原操作叫做“撤销”!

    情况一:文件被修改了,但未执行git add操作(working tree内撤销)

    git checkout fileName
    git checkout .

    情况二:同时对多个文件执行了git add操作,但本次只想提交其中一部分文件

    $ git add *
    $ git status
    # 取消暂存
    $ git reset HEAD <filename>

    情况三:文件执行了git add操作,但想撤销对其的修改(index内回滚)

    # 取消暂存
    git reset HEAD fileName
    # 撤销修改
    git checkout fileName

    情况四:修改的文件已被git commit,但想再次修改不再产生新的Commit

    # 修改最后一次提交 
    $ git add sample.txt
    $ git commit --amend -m"说明"

    情况五:已在本地进行了多次git commit操作,现在想撤销到其中某次Commit

    git reset [--hard|soft|mixed|merge|keep] [commit|HEAD]

    具体参数和使用说明,请查看:Git Pro深入浅出(二)中的重置揭秘部分

    回滚

    上述场景二,已进行git push,即已推送到“远程仓库”中。我们将已被提交到“远程仓库”的代码还原操作叫做“回滚”!注意:对远程仓库做回滚操作是有风险的,需提前做好备份和通知其他团队成员!

    如果你每次更新线上,都会打tag,那恭喜你,你可以很快的处理上述场景二的情况

    git checkout <tag>

    如果你回到当前HEAD指向

    git checkout <branch_name>

    情况一:撤销指定文件到指定版本

    # 查看指定文件的历史版本
    git log <filename>
    # 回滚到指定commitID
    git checkout <commitID> <filename>

    情况二:删除最后一次远程提交

    方式一:使用revert

    git revert HEAD
    git push origin master

    方式二:使用reset

    git reset --hard HEAD^
    git push origin master -f

    二者区别:

    • revert是放弃指定提交的修改,但是会生成一次新的提交,需要填写提交注释,以前的历史记录都在;
    • reset是指将HEAD指针指到指定提交,历史记录中不会出现放弃的提交记录。

    情况三:回滚某次提交

    # 找到要回滚的commitID
    git log
    git revert commitID

    删除某次提交

    git log --oneline -n5

    Git撤销&回滚操作-log

    git rebase -i "commit id"^

    注意:需要注意最后的^号,意思是commit id的前一次提交

    git rebase -i "5b3ba7a"^

    Git撤销&回滚操作-rebase

    在编辑框中删除相关commit,如pick 5b3ba7a test2,然后保存退出(如果遇到冲突需要先解决冲突)!

    git push origin master -f

    通过上述操作,如果你想对历史多个commit进行处理或者,可以选择git rebase -i,只需删除对应的记录就好。rebase还可对 commit 消息进行编辑,以及合并多个commit。

    展开全文
  • git 撤销,放弃本地修改

    万次阅读 2019-06-26 10:09:29
    一、未使用 git add 缓存代码时 可以使用git checkout -- filepathname(比如:git checkout -- readme.md ,不要忘记中间的 “--” ,不写就成了检出分支了!!)。放弃所有的文件修改可以使用git checkout .命令。 ...
  • Git 撤销放弃本地修改

    万次阅读 2019-06-10 16:34:08
    可以使用git checkout -- filepathname(比如:git checkout -- readme.md ,不要忘记中间的 “--” ,不写就成了检出分支了!!)。放弃所有的文件修改可以使用git checkout .命令。 此命令用来放弃掉所有还没有加入...
  • 撤销和回滚其实没啥区别,都是回到以前的某种状态,不过我还是分开写了,可能时因为口语习惯吧 撤销操作 git checkout -- <filename>,放弃文件的当前更改,回到最近一次的提交状态 git reset HEAD <...
  • git 撤销修改

    2019-03-06 12:06:40
    命令git checkout -- readme.txt意思就是,把readme.txt文件在工作区的修改全部撤销,这里有两种情况: 一种是readme.txt自修改后还没有被放到暂存区,现在,撤销修改就回到和版本库一模一样的状态; 一种是readme...
  • Git文件修改,撤销修改,删除

    万次阅读 2018-09-26 19:38:34
      参考廖老师教程 ...工作区有一个隐藏的目录 .git ,这不能算是一个工作区,因为它是隐藏的,它是Git的版本库。 Git的版本库里存了很多的东西,其中最重要的是index(或者叫stage)的暂存区,还有G...
  • git撤销commit,但未git push的命令

    万次阅读 热门讨论 2017-04-23 13:16:51
    git push的时候,有时候我们会想办法撤销git commit的内容 1、找到之前提交的git commit的id git log 找到想要撤销的id 2、git reset –hard id 完成撤销,同时将代码恢复到前一commit_id 对应的版本 3、...
  • git add 撤销操作

    万次阅读 2019-04-16 11:09:09
    添加 多余文件 git add . (空格+ 点) 表示当前目录所有文件,不小心就会提交...git reset HEAD 如果后面什么都不跟的话 就是上一次add 里面的全部撤销git reset HEAD XXX/XXX/XXX.c 就是对某个文件进行撤销了 ...
  • 撤销本地git add操作

    千次阅读 2017-08-25 10:06:39
    撤销本地所有add操作: git reset HEAD . 撤销add操作的某个文件或目录: git reset HEAD -name
  • git add 后如何撤销

    万次阅读 2019-08-22 11:17:53
    git add 操作时,有时会误添加一些不想提交的文件,如何解决? 1、误add单个文件 git reset HEAD 将file退回到unstage区 2、误add多个文件,只撤销部分文件 git reset HEAD 将file退回到unstage区 git rm 与 git ...
  • git 撤销未提交的修改

    万次阅读 2012-09-27 15:51:58
    恢复某个已修改的文件(撤销未提交的修改): $ git checkout file-name revert 还原已提交的修改(已经提交过的修改,可以反悔~) 还原最近一次提交的修改: $ git revert HEAD 还原指定版本的修改: $ ...
  • git撤销已经git add的文件

    万次阅读 2018-12-10 11:45:35
    git add 操作时,有时会误添加一些不想提交的文件,如何解决? 1、误add单个文件 git reset HEAD 将file退回到unstage区 git rm 与 git reset的区别 git rm file_path 删除暂存区和分支上的文件,同时工作区也不需要...
  • Git 撤销commit的注意事项

    万次阅读 2018-06-22 15:21:02
    Git 撤销commit的注意事项Git撤销commit的操作命令 git reset --hard HEAD^一、新建三个文件,demo1,demo2,demo3二、git add 命令提交到暂存区,git reset HEAD demo1就是把提交到暂存区里的文件撤销。上图中,执行...
  • git撤销文件的修改

    万次阅读 2019-08-04 15:48:06
    git撤销某个文件的修改,分为两种情况: 1.在工作区修改,但并未提交到暂存区(即并没有add)。 对于单个文件的撤销修改而言,使用下面方法。 $ git checkout -- 文件名 若想撤销工作区中所有文件的修改,则 $ git ...
  • git撤销已经push的提交

    万次阅读 2018-12-13 14:59:53
    1. git log 2. git reset --soft 43dc0de914173a1a8793a7eac31dbb26057bbee4 3. git push origin master --force     详细版: 1. 使用git log查看提交记录,如: bogon:project name$ git log commit 6c...
  • 撤销git add

    千次阅读 2018-05-02 17:06:46
    对于不小心已经使用git add命令提交的文件,有以下方法可以撤回刚才的操作:1、git reset HEAD -filename2、git rm --cached &lt;filename&gt;如需撤销文件夹加上-rgit rm -r --cached &lt;filename&...
  • git撤销已经push到远端的commit

    万次阅读 多人点赞 2019-02-15 14:21:01
    在使用git时,push到远端后发现commit了多余的文件,或者希望能够回退到以前的版本。先在本地回退到相应的版本:git reset --hard &amp;amp;lt;版本号&amp;amp;gt;如果此时使用命令:git push origin &...
1 2 3 4 5 ... 20
收藏数 34,385
精华内容 13,754
关键字:

git 撤销