git撤销commit 并保存之前的修改
撤销并保留修改
参数 –soft
- # 先进行commit ,之后后悔啦
- $ git commit -am "对首篇报告研究员字段改为author_name"
执行git log
- $ git log
- commit 3d6788f577faba5e1d408e372031c81beee79749
- Author: yous <yous.com>
- Date: Thu Dec 14 10:08:36 2017 +0800
- 添加
- commit 5029f0cc08cffb77f7358de7d5534e8f8eacb82e
- Author: yous <yous.com>
- Date: Thu Dec 14 09:52:39 2017 +0800
- Revert "Revert "修改过程""
- This reverts commit c81f785a06804f5f40b41dedd038efbe6d83f8a8.
- commit c81f785a06804f5f40b41dedd038efbe6d83f8a8
- Author: yous <yous.com>
- Date: Thu Dec 14 09:52:22 2017 +0800
- Revert "修改"
- This reverts commit 5a1d18a032d8c9269613ff14593847f82043e627.
- commit 5a1d18a032d8c9269613ff14593847f82043e627
可以看出,第一个是我刚刚commit
的,我要撤销,当然是选择第二个;
执行命令git reset --soft <commit>
$ git reset --soft 5029f0cc08cf
- 之后我们查看下,状态:
- $ git status
- On branch yutao
- Your branch is up-to-date with 'origin/yutao'.
- Changes to be committed:
- (use "git reset HEAD <file>..." to unstage)
- modified: dataservice/app/ggservice/v1/event/service/InfoEventService.java
可以看出已经回撤啦,并且保留了修改。
参数 –mixed
- $ git reset --mixed 5029f0cc08cff
- Unstaged changes after reset:
- M dataservice/app/ggservice/v1/event/service/InfoEventService.java
- yutao@yutao MINGW64 /d/sts/workspace/ggservice (yutao)
- $ git status
- On branch yutao
- Your branch is up-to-date with 'origin/yutao'.
- 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: dataservice/app/ggservice/v1/event/service/InfoEventService.java
- no changes added to commit (use "git add" and/or "git commit -a")
这种方式也是可以的。
参数--soft
和--mixed
区别:
参数 | 区别 |
---|---|
--soft
|
会将改动放在缓存区 |
--mixed
|
不把改动放在缓存区 |
git reset –hard <commit_id>
这种方式,我个人是不推荐,它也是撤销,但是不会保留修改。
除非你确实是不想要刚刚commit
的内容,否则,这个操作会让你之前干的活,白干。
所以非常不推荐这个方式。
转载于:https://www.cnblogs.com/wwjldm/p/10456078.html
git撤销commit 并保存之前的修改相关推荐
- git撤销commit
写完代码后,我们一般这样 git add . //添加所有文件 git commit -m "本功能全部完成" 执行完commit后,想撤回commit,怎么办? 这样凉拌: gi ...
- git撤销commit到未提交状态_Git在4个阶段5种状态下的撤销操作
在项目开发中我们一般选择GIT作为版本控制,随着项目的不断迭代升级,我们有时候提交代码后想要撤销或者还原,许多童鞋对这些操作不是很熟悉或者很头疼,各种百度比较麻烦,今天我就来总结一下. Git操作的三 ...
- git 撤销commit
撤销未push的commit # 用户已经执行的操作 git add . git commit -m "提示"# 现在想要撤销之前的提交 # 第一种:不删除工作空间提交的代码,撤销 ...
- git 撤销全部的commit_恢复git撤销commit的代码
使用git reset --hard 是将磁盘文件也删除 时候使用Git工作得小心翼翼,特别是涉及到一些高级操作,例如 reset, rebase 和 merge.甚至一些很小的操作,例如删除一个分支 ...
- git 撤销对工作区中文件的修改
对工作区中文件的修改分为三种情况: (1)修改,但没有用git add将修改添加到暂存区: (2)修改,已经使用git add将修改添加到暂存区: (3)修改,已经使用git add将修改添加到暂存区 ...
- idea使用 git 撤销commit
2019独角兽企业重金招聘Python工程师标准>>> 填写commit的id 就可以取消这一次的commit 转载于:https://my.oschina.net/u/35596 ...
- git 撤销全部的commit_git如何撤销commit的方法(未push)
撤销commit一般用git reset ,语法如下: git reset [ --mixed | --soft | --hard] [] 1.使用参数--mixed(默认参数),如git reset ...
- git分支合并、撤销;git修改已push的commit信息; git 撤销操作;
git分支合并 1.分支代码提交 2.git branch 查询本地分支 3.git checkout 分支名1 切换分支到需要合并的分支上 4.git merge 分支名2 //选择要合并到 分支 ...
- Git关于commit的操作,修改message,合并commit,撤销commit
文章目录 Git修改已提交commit的message信息 修改最近一次commit的message 修改之前commit的message 合并commit 合并连续的commit 合并间隔的comm ...
最新文章
- 落地即一地鸡毛,AI落地存在的难题有哪些?
- BMP格式知识之二:16位,24位,32位的BMP图片算法是如何运算的
- 若依前后端分离版数据库已经存在的字典添加一条后刷新没作用,必须清除Redis缓存
- Git的配置SSHKey
- 蜗牛星际 --【功耗测量】
- 抓包红色_抓包三部曲 WebSocket 协议原理抓包分析
- The table(CF-226D)
- 快速排序伪代码_归并排序之入门到quot;放弃quot;
- python3发布时间_什么时候python 3 才能有更好的支持呢?
- (转载)VS2010/MFC编程入门之五十二(Ribbon界面开发:创建Ribbon样式的应用程序框架)...
- 常用的多列等高布局收藏
- 断网会导致xml加载失败数据库失败,识别不了,mybatis官网
- Linux命令之rz命令与sz命令
- 一款简单的取色器:ObtainColor拾色器
- 如何通过个人博客赚钱,走上财务自由?
- mstar v56几路hdmi_TCL MStar常用升级方法图文教程
- arcsin在matlab中怎么输,matlab arcsin
- V4L2框架-视频流的停止(VIDIOC_STREAMOFF)
- 搜索计算机找不到,win7找不到搜索框怎么办?win7找不到搜索框修复方法
- 【vscode插件集】学前端一年,珍藏的 40个 vscode 插件