git commit后怎么撤销

如题所述

1、打开git终端窗口,切换目录,然后git init进行一个初始化动作。

2、git status,可以查看有多少个文件可以加入暂缓区。

3、git add -A,这个时候把状态改为Changes to be committed。

4、git commit -m ""这个时候添加一下注释并且清理工作区。

5、git log查看一下提交的记录。这里一共有两次提交。记录一下log号码。

6、git reset --soft,这样就可以撤销刚刚的commit了,查看status可以核实。

温馨提示:内容为网友见解,仅供参考
第1个回答  推荐于2017-12-16

如果不小心commit了一个不需要commit的文件,可以对其进行撤销。

 

先使用git log 查看 commit日志

commit 422bc088a7d6c5429f1d0760d008d86c505f4abe  
Author: zhyq0826 <zhyq0826@gmail.com>  
Date:   Tue Sep 4 18:19:23 2012 +0800  
  
    删除最近搜索数目限制  
  
commit 8da0fd772c3acabd6e21e85287bdcfcfe8e74c85  
Merge: 461ac36 0283074  
Author: zhyq0826 <zhyq0826@gmail.com>  
Date:   Tue Sep 4 18:16:09 2012 +0800

找到需要回退的那次commit的 哈希值,

 

git reset --hard commit_id 

 

 使用上面的命令进行回退

 

以下是豆瓣的

 

苍炎的日记

 

起因: 不小新把记录了公司服务器IP,账号,密码的文件提交到了git

方法:

    git reset --hard <commit_id>

    git push origin HEAD --force



其他:

    根据–soft –mixed –hard,会对working tree和index和HEAD进行重置:
    git reset –mixed:此为默认方式,不带任何参数的git reset,即时这种方式,它回退到某个版本,只保留源码,回退commit和index信息
    git reset –soft:回退到某个版本,只回退了commit的信息,不会恢复到index file一级。如果还要提交,直接commit即可
    git reset –hard:彻底回退到某个版本,本地的源码也会变为上一个版本的内容


    HEAD 最近一个提交
    HEAD^ 上一次
    <commit_id>  每次commit的SHA1值. 可以用git log 看到,也可以在页面上commit标签页里找到

本回答被网友采纳
第2个回答  2017-10-20

git 已经commit 怎么取消?回退!

回退有三种方式,如下:

git reset --soft  //回退版本将覆盖commit的源代码,保留index file和working tree的源代码。用于修改上传信息可用这条
git reset --mixed  //不带任何参数的git reset,默认使用这种方式。回退版本将覆盖commit和index file的源代码,只保留working tree的源代码。
git reset --hard   //回退版本将覆盖commit、index file和working tree的源代码。(危险操作)

根据你的意思,应该进行软回退操作,运行git reset --soft即可。

第3个回答  2016-05-14
git reset HEAD^1
第4个回答  2019-01-30
git checkout HEAD^

切换到多个版本前:
git checkout HEAD~n /* n为回退版本数 */

相似回答