Git提交错了不用慌,这三招帮你修改记录

本文主要介绍了git中历史记录的修改方法。包括修改最后一次提交,使用--amend参数;修改多个信息,用rebase -i交互式变基;还能进行顺序变更、合并、拆分操作。不过若提交已到远程,需用git push -f强制覆盖,此操作要谨慎。

作者 | 梁唐

来源 | TechFlow(ID:techflow2019)

头图 |  优快云 下载自东方IC

大家好,今天我们来聊聊 git 当中一个很重要的功能——历史记录的修改。

有的时候我们会突然发现某个地方需要修改,最常见的某个不应该被提交的文件被提交了进来。我们希望它不只是在后续的版本当中不再出现,而是希望整个从 git 仓库当中移除掉。这个时候我们就需要修改 git 之前的历史记录。这个时候应该怎么办呢?

不要着急,git 当中有很多的手段可以修改之前的历史提交记录。

修改最后一次提交

这一点我们在之前的文章当中曾经提到过,如果我们只是想要修改最后一次的提交记录,这是比较简单的。我们只需要直接修改我们想要修改的部分,在提交的时候加上一个参数 --amend 即可。

git commit --amend

amend 的意思是补丁,它可以把我们这一次的修改合并到上一条历史记录当中,而不会产生一个新的 commit 记录。运行之后,它会打开一个 vim 编辑器,我们还可以修改上一次 commit 时输入的提示信息。

我们使用 git log 检查的话,会发现历史记录的修改时间还是上一次的时间。看起来就好像什么也没有发生过一样,悄无声息地就改掉了。

修改多个信息

--amend 虽然好用,但是它只能修改最后一次的提交信息,如果我们想要修改的提交记录在那之前,我们应该怎么办呢?

git 当中并没有提供直接的工具来实现这一点,不过我们可以使用 rebase 来达成。我们可以加上-i进行交互式地变基,我们可以在任何想要的修改完成之后停止,也可以添加文件或者是做其他想要做的事情。但是我们变基的目标不是某一个分支而是当前分支的某一个历史节点,所以我们需要提供一个具体的 commitid 或者是指针位置。

git rebase -i 的功能非常强大,我们几乎可以使用它来完成所有一切我们想要完成的事情。

比如我们想要修改倒数第二次提交,我们可以执行 git rebase -i HEAD~3。也就是以倒数第三个节点作为基准节点执行变基,这时候git会进入一个vim窗口,在这个窗口当中我们可以看到最近的三次提交记录。

首先我们可以看到上面的三行就是我们可以修改的三个 commit,分别展示的是要执行的操作以及 commitid 以及 commit message。这里的操作默认的是 pick,也就是使用该 commit。关于我们可以执行的操作 git 在下方也给了充分的提示,其中比较常用的有 pick、edit 以及 squash。

这一次我们想要做的是修改提交记录,所以我们应该执行 edit,我们把想要修改的 commit 前的 pick 改成 edit。比如这样:

退出之后,git 会自动带我们回到我们选择edit的分支提交之后的版本。我们进行我们想要的修改,这里我在第15篇文章当中加上了一行:尝试 rebase。之后再使用 git add 以及 git commit --amend 进行修改提交结果。

再之后我们执行 git rebase --continue,把剩下要应用的变更应用完成。

一切都结束之后,我们可以使用一下 git show 命令查看一下我们修改的 bee9ce3 这个 commit 的记录。可以看到已经多了这一行,说明我们的修改成功了。

顺序变更、合并、拆分

1、顺序变更

我们不仅可以修改某一次 commit 当中的内容,还可以修改这些 commit 的相对顺序,以及可以让它们合并以及拆分。

修改顺序其实很简单,我们只需要人为地修改 rebase -i 之后弹出的 vim 文件即可。比如说原本的记录是:

pick A change A
pick B change B
pick C change C

如果我们想要更换顺序,我们只需要修改这个文件即可。比如变成:

pick B change B
pick A change A
pick C change C

那么当我们在退出 vim 的时候,git 会首先应用 B commit 的变更,再应用 A 最后应用 C。

2、合并

除此之外,我们还可以合并多个 commit 记录成一个。操作的方法也很简单,就是我们只需要把 pick 修改成 squash。git 会自动把所有 squash 的 commit 记录合并在一起。

pick A change A
squash B change B
squash C change

3、拆分

有的时候一个 commit 非常巨大,我们可能也会想要将它拆分,其实操作也很简单。比如我们想要把 commit B 拆分成两条,首先,我们在 rebase 的时候将 commit B 前面的 pick 修改成 edit。

pick A change A
edit B change B
pick C change C

当我们退出的时候,我们会进入到 B commit 刚刚提交完的状态。由于我们要做的是拆分 B 这个提交,所以我们需要执行 git reset HEAD^,把上一次提交重置。然后再分别 add 我们想要拆分开来提交的文件。

整个操作如下:

git reset HEAD^
git add test/*
git ci -m 'add test'
git add code/*
git ci -m 'update code'
git rebase --continue

这样我们就把 commit B 拆分成了两个 commit 插入到了历史记录当中了。

最后的最后,大家需要注意,虽然这些手段在修改记录的时候非常好用。但是如果这些 commit 已经被提交到了远程,我们是不可以直接 git push 同步的。因为 git 会校验我们提交的 hash 值,发现对不上之后会禁止我们的提交。所以如果想要提交到远程的话,只能使用 git push -f 强制覆盖。但是这是一个非常非常危险的操作,如果你 git push -f 了,没有人会知道你到底修改了什么,只建议在自己独有的分支上如此操作,一定一定要谨慎使用。

福 利

优快云旗下公众号全新搜索技能上线啦!

只要在公众号内回复消息

就能自动回复想搜索的内容啦!

现在体验有惊喜,每日参与搜索打卡,

连续打卡满3天、7天、14天

均有优快云精美礼品相送 百分百有礼!快戳

每日体验优快云公众号搜索功能打卡

更多精彩推荐
☞开源数据库再创里程碑,PingCAP 获 2.7 亿美元融资

☞全球数百万台 Mac 疑似因 Big Sur 更新险酿计算灾难,苹果官方回应来了!
☞JavaScript 稳居第一、C# 连续下跌,调查 17000 名程序员后有了这些新发现!
☞中国第一代程序员潘爱民的 30 年程序人生

☞漫画:什么是 “千年虫” 问题?
☞万万没想到 Java 中最重要的关键字竟然是这个!
点分享点点赞点在看
`git reflog` 是 Git 中的一个命令行工具,它记录了从 HEAD 到当前仓库所有引用(如分支、标签等)的历史变动情况,包括每一次提交的 SHA 值、作者、时间以及对应的动作。当你误删了提交或者需要回滚到某个历史版本时,`reflog` 可以派上大用场。 恢复提交的步骤通常如下: 1. 打开终端,在 Git 仓库目录下运行 `git reflog`,这将列出一系列类似于这样的信息: ``` HEAD@{0}: commit (initial): [message] HEAD@{1}: checkout: moving from master to feature HEAD@{2}: commit: [another message] ``` 2. 查找你想要恢复的提交的标识,比如SHA值(`commit` 或者 `{n}` 后面的部分)。假设你要找回第二步的提交,你可以看到 `HEAD@{2}`。 3. 使用 `git reset --hard <commit_id>` 来回到那个提交点,其中 `<commit_id>` 就是你在 `reflog` 输出中找到的那个SHA值。例如,如果 ID 是 `feature~2`(表示两个提交之前),则指令是 `git reset --hard feature~2`。 4. 如果你想把该提交作为一个新的分支而不是直接替换当前工作目录的内容,可以先切换到另一个分支(如 `git checkout -b new_branch_name`),然后再执行 `git reset --hard <commit_id>`。 注意:`git reflog` 记录的是提交的历史,不是文件内容的历史,所以如果你修改过文件并提交了,`reflog` 只能你回到特定的提交状态,无法恢复修改过的文件内容。对于文件内容的恢复,通常依赖于其他备份措施。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值