【Git】合并多次commit提交

原文作者:我辈李想
版权声明:文章原创,转载时请务必加上原文超链接、作者信息和本声明。



前言

在开发阶段,由于我们会频繁的修改代码,会存在多次提交同一个修改,如果我们不合并提交,在于其他人代码合并时,会存在大量的commit提交记录,不利于代码版本。主要用过两个主要命令,分别是git rebase 和git reset。


一、git rebase合并

  1. 切换分支
git branch
git checkout <分支名称>

在这里插入图片描述

  1. 检查代码是否干净
    如果不进行这一步,后边合并时将报错以下错误提示,可先用git status 查看是否有需要提交的文件,没有的话就用git stash
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

  2. 查看commit提交日志,可以q退出

git log --oneline

在这里插入图片描述

  1. 合并分支
    这里的 n 表示最近的 n 个提交数量。如果想要合并所有的提交,则可以省略该参数。我们这里取2
git rebase -i HEAD~n 

git rebase会打开一个vim文本编辑器(需要会修改保存和退出),显示了最近的 n 个提交记录。每个提交前面都有一个 pick 关键字,表示保留该提交。若要合并两个相邻的提交,只需删除第二个提交之前的 pick 关键字,改为 squash 或 s。同样,若要合并更多的提交,只需按照上述操作修改对应的提交行。
在这里插入图片描述

  1. 修改状态
    详细查看第三步和第四部的截图,a463bad是最后一次提交,72615de是倒数第二次提交,我们的需求就是将a463bad合并至72615de,可进行如下修改。
    在这里插入图片描述

  2. 确认
    Esc如果无法退出到保存,可以Esc+鼠标左键。
    在这里插入图片描述
    wq保存并退出后,需要查看message,如果不想改可以继续wq
    在这里插入图片描述
    这里我们可以跟之前图片对照,可以发现1d6494d是合并2次commit的新提交,afc23f7是原来的倒数第三个提交。

  3. 提交到远程仓库

git push -f

二、git reset合并

git reset的本意是版本回退,回退时可以选择保留commit提交。我们基于git reset的作用,结合新建分支,可以实现多次commit提交的合并。这个不需要vim编辑,很少有冲突。

  1. 基于现在的banch新建分支
  2. 在新分支中打开git log
  3. 选择一个想要合并的版本进行reset
  4. 重新查看push内容,进行commit提交,这次提交将合并所有,推送至远程新分支
  5. 如有需要,现在可以删除旧分支使用新分支

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 10
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我辈李想

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值