(详解踩坑)GIT版本回滚git stash、git reset、git reset --hard、git revert

目录

背景

[一、(git log、git reflog)查看git提交日志及命令历史](#一、(git log、git reflog)查看git提交日志及命令历史)

[1.1 git log(提交日志)](#1.1 git log(提交日志))

[1.2 git reflog(命令历史)](#1.2 git reflog(命令历史))

[二、git reset(回退到指定的版本,并且保留更改)](#二、git reset(回退到指定的版本,并且保留更改))

[2.1 回退到指定版本](#2.1 回退到指定版本)

[2.2 快捷回退上一版本](#2.2 快捷回退上一版本)

[三、git reset --hard(回退到指定版本,不保留更改)](#三、git reset --hard(回退到指定版本,不保留更改))

[四、git revert(回退到指定版本,保留commit记录)](#四、git revert(回退到指定版本,保留commit记录))

[五、git stash](#五、git stash)

六、注意

[6.1 不小心git reset --hard回退了,怎么回到以前版本](#6.1 不小心git reset --hard回退了,怎么回到以前版本)

[6.2 git log和git reflog的应用场景](#6.2 git log和git reflog的应用场景)

[6.3 git reset和git revert的区别](#6.3 git reset和git revert的区别)


背景

我们开发过程中会遇到git数据提交错误、代码回滚,或者一些没用的comit进行合并,优化commit展示

一、(git log、git reflog)查看git提交日志及命令历史

1.1 git log(提交日志)

git 记录着所有的提交日志,通过log命令可以读取过去的提交记录 ,得到commit id即版本的哈希码

复制代码
git log
 四行详细记录,包括的信息有commit id、提交者、提交时间、备注
git log --pretty=oneline
输出的每个提交记录只占据一行,每行的显示内容为commit id + 备注

1.2 git reflog(命令历史)

通过relog命令可以读取过去的命令历史

复制代码
git reflog

二、git reset(回退到指定的版本,并且保留更改)

2.1 回退到指定版本

回退的同时,将回退对应版本到目前版本的commit信息记录将删除、代码不会删除、只是合并commit记录(用这个可以合并多个commit、来使commit记录看起来整洁)

复制代码
git reset <commit>

2.2 快捷回退上一版本

如果要回退到上一个版本,可以使用以下 Git 命令:

复制代码
git reset HEAD^

这个命令将会将当前版本回退到上一个版本,HEAD^ 表示上一个版本,HEAD^^表示上上个版本。

如果想回退更多个版本,用 HEAD~n 即可,比如回退到前5个版本:

复制代码
git reset HEAD~5

三、git reset --hard(回退到指定版本,不保留更改)

回退的同时,将代码和commit记录都将回退到指定版本(放弃目标版本以后的所有修改)

复制代码
git reset --hard <commit>

四、git revert(回退到指定版本,保留commit记录)

回退项目版本时,可以运行 git revert 命令,该命令会回退指定版本的修改,并创建一个新的提交来存储这些被撤销的更改。

复制代码
git revert --no-commit <commit>..HEAD

五、git stash

执行git stash 将当前所有未提交的代码修改,都不保留,撤销更改

复制代码
git stash

六、注意

6.1 不小心git reset --hard回退了,怎么回到以前版本

可以使用git reflog 来查看命令记录,然后再用git reset --hard 记录id 来进行复原

6.2 git log和git reflog的应用场景

git log是commit记录,git reflog是git 命令记录,同时这两个查看命令配合git reset(git reset --hard)可以让你在不同版本之间游刃有余

6.3 git reset和git revert的区别

reset执行后不会产生记录,revert执行后会产生记录。

相关推荐
AI成长日志1 天前
【实用工具教程】Git进阶:分支策略与合并冲突解决
git
ruanCat1 天前
加了 .gitattributes 就万事大吉?我差点毁了整个团队的 Git 工作流
git
咋吃都不胖lyh1 天前
查看 Git 本地仓库关联的远程仓库链接(URL)
git
wheelmouse77881 天前
AI 时代的 Git 进阶术:如何优雅地让多个 Agent 并行开发
人工智能·git·ai编程
如意.7592 天前
【Linux开发工具实战】Git、GDB与CGDB从入门到精通
linux·运维·git
用户9186861286872 天前
Git 版本控制完全指南:从入门到精通
git
简离2 天前
Git 一次性清理已跟踪但应忽略文件
前端·git
Drone_xjw2 天前
【环境搭建】Windows 10上使用Docker搭建本地Git仓库(Gitea)完整教程
windows·git·docker
疯狂成瘾者2 天前
git学习目录
git·学习
曾几何时`2 天前
Git——自用手册
git