Git撤销修改

Git撤销修改

如果因为各种原因,需要回滚至上个版本,可以使用特定的命名实现。

首先回退分为回退工作区、回退暂存区、回退版本库。回退的命令是层层递进的,如回退暂存区的命令实际是将工作区和暂存区都回退,回退版本库的命令实际是将三个区都回退。

要注意的是,git 只会对在 git 中已被版本控制的文件 进行操作,即,在相关目录下被忽略的文件、未跟踪 (从没被添加到暂存区或版本库中)的文件,在版本回退时都不会受到影响

bash 复制代码
git reset --soft --mixed --hard HEAD

--soft 会将版本库的内容回退,但工作区和暂存区的内容不变。

--mixed 是缺省操作,会将版本库和暂存区的内容回退,但工作区的内容不变。

--hard 会将三个区的内容全都同步到上一个版本。

HEAD 表示当前版本,^ 表示上一版本,需要回退到多少个版本前,就加几个 ^

1. 撤销工作区修改

bash 复制代码
git checkout -- [filename]	//将某个文件的内容回退到版本库最新的备份

2. 撤销工作区和暂存区修改

^ 表示一个版本,要回退到多少个版本前就输入多少个 ^

bash 复制代码
git reset --mixed HEAD^

3. 撤销版本库修改

注意如果使用的是远程仓库,撤销版本库修改要在执行 push 命令之前,否则版本回退后再提交再执行 push 会产生远程仓库和本地仓库的分支冲突。

bash 复制代码
git reset --hard HEAD^

如果执行 push 命令后,仍然要回退版本库,要注意不能执行回退后再 push ,因为本地仓库的提交版本是不能比远程仓库的提交版本低的。而是要使用:

bash 复制代码
git revert HEAD^

这个命令会将当前仓库的内容回退到上一个版本,并生成一个新的提交 ,这样就能解决本地版本低而不能 push 到远程仓库的问题。

相关推荐
F_D_Z37 分钟前
【清晰教程】查看和修改Git配置情况
git
漫谈网络2 小时前
保持本地 Git 项目副本与远程仓库完全同步
git
李天琦7 小时前
git查看commit属于那个tag
linux·git·云计算
Hoking10 小时前
CentOS7.9环境离线部署docker和docker-compose的两种方式
git·docker·容器
Clownseven10 小时前
用Git管理你的服务器配置文件与自动化脚本:版本控制、变更追溯、团队协作与安全回滚的运维之道
运维·服务器·git
F_D_Z12 小时前
【清晰教程】利用Git工具将本地项目push上传至GitHub仓库中
git·github
天天摸鱼的java工程师15 小时前
Git 分支管理规范:从理论到实战的企业级最佳实践
java·git·后端
深兰科技16 小时前
青岛市长任刚与深兰科技董事长陈海波会谈,深兰青岛项目即将进入快车道!
人工智能·git·docker·jupyter·深兰科技·青岛项目·陈海波
2401_8742751718 小时前
linux、docker、git相关操作
linux·git·docker
化作繁星1 天前
git忽略校验,强制提交
git