300字范文,内容丰富有趣,生活中的好帮手!
300字范文 > 【Git】Git 基础命令 ( 查看提交记录 git log | 版本回滚 git reset | 撤销回滚 git reflog )

【Git】Git 基础命令 ( 查看提交记录 git log | 版本回滚 git reset | 撤销回滚 git reflog )

时间:2021-12-12 21:31:55

相关推荐

【Git】Git 基础命令 ( 查看提交记录 git log | 版本回滚 git reset | 撤销回滚 git reflog )

文章目录

一、查看提交记录 git log1、查看详细提交记录2、查看简略提交记录二、版本回滚 git reset1、Git 中的版本表示 HEAD~12、版本库代码回滚三、撤销回滚1、查询 git 操作 git reflog2、撤销回滚操作 git reset --hard dd0db50

一、查看提交记录 git log

1、查看详细提交记录

在 Git 版本库 中 , 可以查询每一次 使用git commit命令的提交记录 , 每次git commit提交都会保留一个快照 , 如果工程代码弄坏了 , 可以尝试从最近的一次git commit提交的快照进行恢复 ;

执行

git log

命令 , 会显示之前的提交记录 , 排序由近及远 ;

由打印的内容可以看出 , 最近的一次提交时 修改了 file2.txt 文件 ;

D:\Git\git-learning-course>git logcommit dd0db50c74c065dc8ad569ec41267a9c881e7d7e (HEAD -> master)Author: hanshuliang <octopus_truth@>Date: Wed Dec 8 11:31:48 +0800modify file2

2、查看简略提交记录

执行

git log --pretty=oneline

命令 , 可以查看简略提交目录 ;

执行过程 :

D:\Git\git-learning-course>git log --pretty=onelinedd0db50c74c065dc8ad569ec41267a9c881e7d7e (HEAD -> master) modify file263a9ef1a546c4d30c0e4f74ac2258b37bd585254 modify file172e82e0652ff454f83fa26e7ad186a74e69090e1 modify file45bcec31df6d485a957681f9f35b6d0461d19abf3 add 1 filesf95c831c111e8fa4d79cbdacc6ea306cde399959 add 3 filesf2f9a971bfc65c1067d8ee2907362c0b92a29fe6 (origin/master, origin/HEAD) Update README.md5d7e8d4eee3def7d8e094fdee1508fb2e7b0c790 Initial commitD:\Git\git-learning-course>

二、版本回滚 git reset

下图是 Git 版本库 最近的git commit提交 记录 ;

1、Git 中的版本表示 HEAD~1

Git 中的版本表示 :

HEAD表示当前的版本 , 是dd0db50c74c065dc8ad569ec41267a9c881e7d7e (HEAD -> master) modify file2版本 , 当前版本 , 查询出的第 111 个版本 ;HEAD~1表示上一个版本 , 是63a9ef1a546c4d30c0e4f74ac2258b37bd585254 modify file1版本 , 往上 111 个版本 , 查询出的第 222 个版本 ;HEAD~2表示上上一个版本 , 是72e82e0652ff454f83fa26e7ad186a74e69090e1 modify file4版本 , 往上 222 个版本 , 查询出的第 333 个版本 ;HEAD~3表示上上上一个版本 , 是5bcec31df6d485a957681f9f35b6d0461d19abf3 add 1 files版本 , 往上 333 个版本 , 查询出的第 444 个版本 ;HEAD~100表示往上 100100100 个版本 , 是查询出的第 101101101 个版本 ;

2、版本库代码回滚

执行

git reset --hard HEAD~1

命令 , 就是往上回滚一个版本 , 回滚到63a9ef1a546c4d30c0e4f74ac2258b37bd585254 modify file1版本 , 这个版本中 file2.txt 不是空的 , 当前是有内容的 ;

执行回滚到上一个版本命令后 , file2.txt 文件中的内容消失 ;

三、撤销回滚

1、查询 git 操作 git reflog

执行

git reflog

命令 , 可以查询之前进行的 每一次 git 命令 ;

执行过程 :

D:\Git\git-learning-course>git reflog63a9ef1 (HEAD -> master) HEAD@{0}: reset: moving to HEAD~1dd0db50 HEAD@{1}: reset: moving to dd0db5063a9ef1 (HEAD -> master) HEAD@{2}: reset: moving to HEAD~1dd0db50 HEAD@{3}: reset: moving to dd0db5072e82e0 HEAD@{4}: reset: moving to HEAD~163a9ef1 (HEAD -> master) HEAD@{5}: reset: moving to HEAD~1dd0db50 HEAD@{6}: reset: moving to HEADdd0db50 HEAD@{7}: reset: moving to HEADdd0db50 HEAD@{8}: reset: moving to HEADdd0db50 HEAD@{9}: commit: modify file263a9ef1 (HEAD -> master) HEAD@{10}: commit: modify file172e82e0 HEAD@{11}: commit: modify file45bcec31 HEAD@{12}: commit: add 1 filesf95c831 HEAD@{13}: commit: add 3 filesf2f9a97 (origin/master, origin/HEAD) HEAD@{14}: clone: from /han1201/git-learning-courseD:\Git\git-learning-course>

2、撤销回滚操作 git reset --hard dd0db50

上一步操作 , 是由 HEAD 位置指向了 HEAD~1 位置 ,

63a9ef1 (HEAD -> master) HEAD@{0}: reset: moving to HEAD~1

可以重新撤销回滚 , 恢复到回滚之前的状态 ,

dd0db50 HEAD@{6}: reset: moving to HEAD

可以知道 , HEAD 的版本号是 dd0db50 ;

执行

git reset --hard dd0db50

命令 , 即可恢复成回滚之前的代码状态 ;

执行过程 :

D:\Git\git-learning-course>git reset --hard dd0db50HEAD is now at dd0db50 modify file2D:\Git\git-learning-course>

此时再查看 file2.txt 内容 , 发现内容恢复成了原来的样子 ;

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。