git-怎样把连续的多个commit合并成一个?

Git怎样把连续的多个commit合并成一个?

Git怎样把连续的多个commit合并成一个?

参考URL: https://www.jianshu.com/p/5b4054b5b29e

  1. 查看git日志
bash 复制代码
git log --graph

比如下图的commit 历史,想要把bai "Second change" 和 "Third change" 这两个commit合并到一起
那么,可以

bash 复制代码
git rebase -i 7a734e9d47895e096313003d6a2e4f697a16e2e3

注意 7a734e9d47895e096313003d6a2e4f697a16e2e3 是 "Second change" 的前bai一个commit ID。

然后会出现bai编辑器 (具体什么编辑器看你的配置,在linux下,默认是 vi)列出从 7a734e 后面的所有commit,如下图:
因为我们要把 "Second change" 和 "Third change" 合并到一起,所以只需要把 "Third change"前面的那个 pick 改成 squash即可,意思是将 "Third change" 和 它前一个commit (即 "Second change") 合并

修改后应该是这样

默认的包括了两个commit的原始消息,你可以在这里任意修改commit message,比如改成 "Second and Third changes in single commit",然后保存退出,git就会把这两个commit变成一个新的commit。做完后我们再用git log看一下,就会变成下图
对比原始git log信息,你就可以发现两个commit被合成一个了。

同理,你可以将任意多个commit合并成一个 (第一个commit保持 pick, 后续commit改成 squash即可)

  1. 取要合并的commit最早那个的父亲ID进行变基
    使用命令
bash 复制代码
git rebase -i
相关推荐
SStone_TJ10 小时前
【常用的git命令】
git
没有鸡汤吃不下饭10 小时前
Git将某个分支合并到开发(dev)、测试(test)后突然想撤销该分支的功能,怎么处理?
前端·git·github
康一夏11 小时前
git fatal:Server aborted the SSL handshake
git·网络协议·ssl
Vio7251 天前
在IntelliJ IDEA中使用Git
git
Net_Walke1 天前
git 的常用命令
git·物联网·github·iot
L X..1 天前
Git 无法访问 GitHub(Recv failure: Connection was reset)问题解决教程
git·github
建群新人小猿1 天前
客户标签自动管理:标签自动化运营,画像持久保鲜
android·java·大数据·前端·git
来一颗砂糖橘2 天前
Git 进阶指南:深入掌握 git log 查看提交历史
git·版本控制·开发技巧
六点半8882 天前
【Git】远程操作 + 给命令配置别名 + 标签管理
git
虫师c2 天前
GitOps实战:ArgoCD+Tekton打造云原生CI/CD流水线
git·ci/cd·云原生·kubernetes·argocd·tekton