什么是管理修改?
管理修改 这个概念虽然比较抽象,但对 Git 很重要,也是它比其他版本控制系统设计得优秀的原因。
Git 管理的是修改,而不是文件。那什么是修改呢:
查看修改
执行 git diff HEAD -- {filename} 命令可以查看工作区和版本库中最新版本的区别,也就是查看修改了什么。
执行一次 git commit 就会生成一条提交记录,好比“保存了一个快照”,也就是一个我们说的版本。每次 commit 成功,都会生成一个版本。
使用 git log 查看版本记录(也就是历史提交记录)
版本回退应该在 git commit 执行成功之后进行。
git reset --hard HEAD^ 表示回退到上一个版本
Git必须知道当前版本是哪个版本,在Git中,
用HEAD表示当前版本,也就是最新的提交1094adb…(注意我的提交ID和你的肯定不一样),
上一个版本就是HEAD^,
上上一个版本就是HEAD^^,
当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100。
git reset --hard {commit-id前五位}
可通过命令 git reflog 或 git log --oneline 查询提交记录,第一列就是commit id。
工作区产生了修改,要撤销修改,分两种情况来说:
git add,可执行下面的命令撤销修改:git checkout -- {filename}
git restore {filename} # 新增
git add将修改放到了暂存区,如果还没有commit ,此时撤销修改需要两个步骤:git restore --staged {filename} 将修改从缓存区撤回到工作区(缓存区中修改将被丢弃);git restore {filename} 将工作区中的修改丢弃,就完成了撤销修改。如果已经执行了
commit,请使用版本回退进行处理。
通常是在文件管理器中删除文件,或者通过 rm 命令删除。
上面讲过,删除文件也是一种修改,此时可以有两种选择:
git restore {filename}进行还原。git add {filename},然后执行git commit这样文件就从版本库中删除了。删除是危险操作,一般我们需要注意以下两点:
- 从来没有被添加到版本库就被删除的文件,是无法恢复的;
- 如果一个文件已经被提交到版本库,则永远不用担心文件被删除,但只能恢复到最新版本,会丢失最近一次提交后修改的内容。
🔥BuildAdmin是一个永久免费开源,无需授权即可商业使用,且使用了流行技术栈快速创建商业级后台管理系统。