Git使用:版本回退
在Git中,我们可以用 git log命令查看我们修改的历史记录
C:\Users\Administrator\Documents\GitHub\learngit [master]> git log
commit 06da0ffc8ff902d1b7d55968dd2822a6e0cc7ac9
Author: Tryking <260119064@qq.com>
Date: Thu Mar 10 14:29:22 2016 +0800
add World
commit f4fa07feb10862f0d0d6a44fb88f5ede6ae75771
Author: Tryking <260119064@qq.com>
Date: Thu Mar 10 13:57:50 2016 +0800
wrote a readme file
git log命令显示从最近到最远的提交日志,我们可以看到2次提交,最近的一次是add World,最早的一次是wrote a readme file。
如果嫌输出信息太多,看得眼花缭乱的,可以试试加上–pretty=oneline参数:
C:\Users\Administrator\Documents\GitHub\learngit [master]> git log --pretty=oneline
06da0ffc8ff902d1b7d55968dd2822a6e0cc7ac9 add World
f4fa07feb10862f0d0d6a44fb88f5ede6ae75771 wrote a readme file
查看了修改的历史记录后,我们就可以用 git reset 进行版本回退了
首先,Git必须知道当前版本是哪个版本,在Git中,用HEAD表示当前版本,也就是最新的提交06da0ffc8ff902d1b7d55968dd2822a6e0cc7ac9(这个是commit id,是一个SHA1计算出来的一个非常大的数字,用十六进制表示),上一个版本就是HEAD^,上上一个版本就是HEAD^^,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100。
现在,我们要把当前版本“add World”回退到上一个版本“wrote a readme file”,就可以使用git reset命令:
C:\Users\Administrator\Documents\GitHub\learngit [master]> git reset --hard HEAD^
HEAD is now at f4fa07f wrote a readme file
之后我们可以用 cat 命令查看readme.txt的内容是不是回退回去的版本
C:\Users\Administrator\Documents\GitHub\learngit [master]> cat readme.txt
Hello
我们用 git log 再看看现在版本库的状态:
C:\Users\Administrator\Documents\GitHub\learngit [master]> git log
commit f4fa07feb10862f0d0d6a44fb88f5ede6ae75771
Author: Tryking <260119064@qq.com>
Date: Thu Mar 10 13:57:50 2016 +0800
wrote a readme file
最新的那个版本 add World 已经看不到了!想再回去已经回不去了,怎么办?
办法其实还是有的,只要上面的命令行窗口还没有被关掉,你就可以顺着往上找啊找啊,找到那个add World的 commit id 是06da0ffc8ff…,于是就可以指定回到未来的某个版本:
C:\Users\Administrator\Documents\GitHub\learngit [master]> git reset --hard 06da
HEAD is now at 06da0ff add World
版本号没必要写全,前几位就可以了,Git会自动去找。当然也不能只写前一两位,因为Git可能会找到多个版本号,就无法确定是哪一个了。
再看看readme.txt的内容:
C:\Users\Administrator\Documents\GitHub\learngit [master]> cat readme.txt
HelloWorld
Git可以记录你的每次命令:git reflog
现在,假如你回退到了某个版本,关掉了电脑,第二天早上就后悔了,想恢复到新版本怎么办?找不到新版本的commit id怎么办?
Git提供了一个命令 git reflog 用来记录你的每一次命令:
C:\Users\Administrator\Documents\GitHub\learngit [master]> git reflog
06da0ff HEAD@{0}: reset: moving to 06da
f4fa07f HEAD@{1}: reset: moving to HEAD^
06da0ff HEAD@{2}: commit: add World
f4fa07f HEAD@{3}: commit (initial): wrote a readme file
这样你就可以看到你需要的 commit id 了,放心的回去吧!
Git使用:版本回退的更多相关文章
- Git(时光机-版本回退)
现在,你已经学会了修改文件,然后把修改提交到Git版本库,现在,再练习一次,修改readme.txt文件如下: Git is a distributed version control system. ...
- Git学习--版本回退
现在,你已经学会了修改文件,然后把修改提交到Git版本库,现在,再练习一次,修改readme.txt文件如下: Git is a distributed version control system. ...
- idea中git远程版本回退
idea中git远程版本回退 2017年10月15日 15:25:36 gomeplus 阅读数:19313 工作中遇到git远程仓库需要回退到历史版本的问题,根据网上的搜索结果结合自己的实践,整理了 ...
- git指令-版本回退
git指令-版本回退 回顾: 1. 修改文件 2. 添加到暂存区并提交 回顾对readme共三次修改: 1. 版本1:wrote a readme file Git is a version cont ...
- Git回版本回退
这里我们使用命令行的方式对已经提交的版本进行强行回退操作~~~ 一.将git的安装目录bin放到path路径中, 如下图所示: 二.进入cmd界面,依次输入下面内容即可(git 远程仓库 回退到指定版 ...
- git远程版本回退
本文为博主原创,未经允许不得转载: 之前在git提交版本时,发现将新开发的代码提交到了另一个分支上,为了不影响提交分支代码的 功能,需要回退到之前的版本. 在使用命令回退的时候,一直没有回退成功,有个 ...
- git实现版本回退
1. 首先查看自己的版本: ***:~/piaoshifu_object/epiao.piaoshifu.cn$ git log commit c8d5c67861d2d0e21856cc2b4f60 ...
- git reset 版本回退的三种用法总结
git reset (–mixed) HEAD~1 回退一个版本,且会将暂存区的内容和本地已提交的内容全部恢复到未暂存的状态,不影响原来本地文件(未提交的也不受影响) git reset –soft ...
- git reset 版本回退
git log 查看所有提交信息. commit 67692318180bed6b2a17db0708cfbe0231e33db3 (HEAD -> master) Author: kingBo ...
- git的版本回退探索
简介 今天改完代码匆忙提交,上线发现有问题,那怎么办?废话,赶紧回滚,那怎么回滚,开始用git reset [--soft | --mixed | --hard 命令,但这命令真的能达到我预期的效果吗 ...
随机推荐
- Linux中find命令与三剑客之grep和正则
昨日内容回顾 1.每个月的3号.5号和15号,且这天时周六时 执行 00 00 3,5,15 * 6 2.每天的3点到15点,每隔3分钟执行一次 */3 3-15 * * * 3.每周六早上2点半执行 ...
- CF1520D Same Differences 题解
Content 给定 \(n\) 个数 \(a_1,a_2,\dots,a_n\),求有多少个二元组 \((i,j)\) 满足: \(i<j\). \(a_j-a_i=j-i\). 数据范围:\ ...
- LuoguB2105 矩阵乘法 题解
Content 给定一个 \(n\times m\) 的矩阵 \(A\) 和一个 \(m\times k\) 的矩阵 \(B\),求两个矩阵相乘得到的矩阵. \(n\times m\) 的矩阵 \(A ...
- java 网络编程基础 UDP协议的Socket:DatagramSocket;广播Socket:MulticastSocket
什么是UDP协议: UDP协议是一种不可靠的网络协议,它在通信实例的两端各建立一个Socket 但这两个 Socket之间并没有虚拟链路,这两个Socket只是发送.接收数据报的对象.Java 提供了 ...
- linux查看磁盘SN
ls -l /dev/disk/by-id/ | grep -iE <SN>
- More Effective C++ 基础议题(条款1-4)总结
More Effective C++ 基础议题(条款1-4)总结 条款1:仔细区别pointers和references 如果有一个变量,其目的是用来指向(代表)另一个对象,但是也有可能它不指向(代表 ...
- 钉钉提供的内网穿透之HTTP穿透
此方法无需自行提供服务器和域名 官方地址:https://developers.dingtalk.com/document/resourcedownload/http-intranet-penetra ...
- SpringBoot单元测试demo
引入maven <dependency> <groupId>org.springframework.boot</groupId> <artifactId> ...
- c++11之字符串格式化
1.关于 我知道的,C++20中引入了相当方便的字符串格式化,有兴趣的朋友,可以看下fmt库,截至目前,它实现了c++20中引入的字符串格式化绝大部分功能. 2.format 既然c++11中没有方便 ...
- King's Order(hdu5642)
King's Order Accepts: 381 Submissions: 1361 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: ...