git push撤销、git commit 撤销、git add撤销、修改git提交信息
虽然自觉是一个Git工具的老手了,但是平时犯了一点错误,就发现有点捉襟见肘了。就好像今天我把一些代码玩坏了,想撤回到前几个版本去(此时已经push到远程分支),但是仔细一想:卧槽,这操作我好像不太熟练啊,于是乎就有了这篇文章了。
一、git push撤销
1.1 使用场景
代码已经修改并push到远程分支,想撤回到前几个版本,并且会删除本地代码所做的修改!
1.2 示例场景
如下图。

1.3 示例目标
撤销第二、第三次提交代码,回到第一次提交代码
1.4 详细步骤
1.4.1 获取第一次提交commit版本号
在idea的Terminal窗口输入git log查看提交日志,结果如图:

将目标commit版本号复制保存留用。
如果git log无法正常显示中文,在Terminal中使用如下命令:
set LESSCHARSET=utf-8
1.4.2 将本地代码撤销至目标commit版本(高危操作,请明确利害关系)
执行命令:
git reset --hard 57f89f403fd8b373a44cf5ae8481402a74799bee
结果:
HEAD is now at 57f89f4 'Git演示:第一次提交'
验证结果:
本地分支log

远程分支log

此时,本地分支第二、第三次提交已经撤销删除了!
1.4.3 覆盖远程分支代码(高危操作,请明确利害关系)
请明确本地分支代码是最终的代码!否则谨慎操作!执行命令:
git push --force
执行完这一步,git push撤销操作就完成了,git log如图:

二、git commit撤销
2.1 使用场景
代码已经git add,并且git commit,但是还没有git push
2.2 命令使用
git reset --soft HEAD~1
## 如果进行了2次commit,想都撤回,可以使用:
git reset --soft HEAD~2
## ... 以此类推
三、git add撤销
3.1 使用场景
代码已经执行了git add操作,想撤销git add操作。
3.2 命令使用
## 全部撤销
git reset HEAD
## 指定文件撤销 git reset HEAD <file>,文件名可通过git status命令获取。
git reset HEAD src/main/java/wang/leisure/gitpractice/FirstClass.java
四、修改git提交信息
4.1 使用场景
不修改代码内容,只修改commit信息,在git commit操作之后,git push操作之前。如果你在git push之后操作,也会将本地commit信息变更,但是这样会导致与远程分支信息不一致,所以尽量不要在git push之后操作。
4.2 命令使用
直接在Terminal中输入:
git commit --amend
命令输入之后,就是Vim类似的修改、保存操作了。
五、恢复文件到上一次提交时的样子
5.1 使用场景
文件做了很多修改,但是还没有git add,又不想一步步回退。
5.2 命令使用
## 文件名可通过git status命令获取
git checkout -- src/main/java/wang/leisure/gitpractice/FirstClass.java
至此,有关git操作撤销相关的内容就分享结束了,有任何不懂的可以留言哦。深夜1:15了,如果文章对你有帮助希望关注支持一下。
原文地址:http://leisure.wang/?p=472
git push撤销、git commit 撤销、git add撤销、修改git提交信息的更多相关文章
- Git 修改历史提交信息 commit message
修改最近一条提交的消息 git commit --amend 进入vim模式 按字母 o 或者 insert键 开始修改内容 按 esc 推出编辑,最常用的是输入":q"直接退出, ...
- git 修改上次提交信息 与 撤销此操作.
git commit --amend 修改刚才提交的commit信息 撤销 git commit --amend 思路是使用 git reflog 查看在哪里ammend的.找到HEAD{N}, N是 ...
- git 修改历史提交信息
当你不小心,写错了提交的注视/信息,该如何处理呢.理论上,SCM是不应该修改历史的信息的,提交的注释也是. 不过在git中,其commit提供了一个--amend参数,可以修改最后一次提交的信息. ...
- git push完代码 想撤回 并保留之前修改的代码 / 修改完代码 发现分支不对 想切换分支 /恢复已修改的文件
git reset --soft xxxx // xxxx是版本号 回退 git stash //保留当前分支修改的代码 git checkout xxx //切换到xxx分支 git stash l ...
- git git push某一次的commit记录
$ git push <remote name> <commit hash>:<remote branch name> # Example:$ git push o ...
- git add , git commit 添加错文件 撤销
1. git add 添加 多余文件 这样的错误是由于, 有的时候 可能 git add . (空格+ 点) 表示当前目录所有文件,不小心就会提交其他文件 git add 如果添加了错误的文件的话 撤 ...
- 02_创建Git仓库,克隆仓库,git add,git commit,git push,git pull,同行冲突,不同行冲突的结局方案,git mergetool的使用
1 创建Git资源库,残酷目录信息 创建git资源库的命令: git init –bare 仓库名称 (其中-bare表示的意思是空的库的意思) 进入E:\software\repository\gi ...
- git push 提示
我运行git push -u origin master 时提示如下: To git@github.com:userName/project.git ! [rejected] master -> ...
- git push 本地项目推送到远程分支
大家有的时候,会在本地新建项目,这里说一下在本地项目建立本地git仓库,然后push到远程仓库的步骤 1.在本地项目的文件夹下,git仓库初始化 git init 初始化本地git仓库 2. git ...
- git push 本地项目推送到远程分支[z]
大家有的时候,会在本地新建项目,这里说一下在本地项目建立本地git仓库,然后push到远程仓库的步骤 1.在本地项目的文件夹下,git仓库初始化 git init 初始化本地git仓库 2. git ...
随机推荐
- mac使用brew安装mysql5.7
安装mysql5.7 brew install mysql@5.7 设置环境变量(可能安装完自动生成过了,可以cat ~/.zshrc看一下,有了就不用添加了 ) echo 'export PATH= ...
- Golang Map实现(四) map 的赋值和扩容
title: Golang Map 实现 (四) date: 2020-04-28 18:20:30 tags: golang map 操作,是map 实现中较复杂的逻辑.因为当赋值时,为了减少has ...
- Spring5参考指南:基于注解的容器配置
文章目录 @Required @Autowired @primary @Qualifier 泛型 @Resource @PostConstruct和@PreDestroy Spring的容器配置可以有 ...
- php private学习笔记
类的权限修饰符,放在属性/方法的前面.用来说明属性/方法的权限特点. 三种权限修饰符 private 私有的 public 公共 protected 保护的 privata 的属性.方法只能在 ...
- 【kafka KSQL】游戏日志统计分析(1)
[kafka KSQL]游戏日志统计分析(1) 以游戏结算日志为例,展示利用KSQL对日志进行统计分析的过程. 启动confluent cd ~/Documents/install/confluent ...
- div/dom元素拖拽缩放插件,纯js实现拖拽缩放,不依赖jQuery~
产品需求,需要用到对div(dom)进行拖拽缩放操作,看到有好多插件,要么依赖jQuery,要么文件太大. 封装了一个插件,不压缩状态下5KB. html <!DOCTYPE html> ...
- 《Android游戏开发详解》一1.7 控制流程第1部分——if和else语句
本节书摘来异步社区<Android游戏开发详解>一书中的第1章,第1.7节,译者: 李强 责编: 陈冀康,更多章节内容可以访问云栖社区"异步社区"公众号查看. 1.7 ...
- dijkstra preiority_queue优化 紫书学习
#include<bits/stdc++.h> using namespace std; const int maxn=1000+10; const int INF=1000000000; ...
- 打造livecd的注意事项
一:在CentOS.ks的定制脚本中,删除syslinux组件:出错提示: /usr/lib/python2.6/site-packages/imgcreate/errors.py:45: Depre ...
- C++--浅谈开发系统的经验
最近写了不少类了,从垃圾代码爬坑,虽然还是很垃圾,但是照葫芦画瓢,有几分神韵.在这里总结一下,写类的经验教训. 第一步 分析: 当拿到一个要求时,要先去考虑怎样一个类到底该实现什么样的功能,有什么样的 ...