ThinkChat🤖让你学习和工作更高效,注册即送10W Token,即刻开启你的AI之旅 广告
简介 在日常开发中,代码变更比较频繁,有时候想让前几次提交的合并为一次提交,这里可以使用git rebase -i 命令来完成,当然,git rebase命令不仅仅用于合并提交,它还有许多用处,比如可以使用git rebase onto将某一段commit粘贴到另一个分支上等等,这里主要介绍合并提交。 命令介绍 rebase为变基 git rebase -i 命令可以压缩合并多次提交 格式:`git rebase -i [startpoint] [endpoint]` 其中-i的意思是–interactive,即弹出交互式的界面让用户编辑完成合并操作,[startpoint] [endpoint]则指定了一个编辑区间,如果不指定[endpoint],则该区间的终点默认是当前分支HEAD所指向的commit(注:该区间指定的是一个前开后闭的区间)。 在查看git的log后,可以使用如下命令 // 合并从当前head到15f745b(commit id) `git rebase -i 15f745b` 或: // 合并最近的两次提交 git rebase -i HEAD~2 ``` // 合并从当前head到15f745b(commit id) git rebase -i 15f745b 或: // 合并最近的两次提交 git rebase -i HEAD~2 ``` 执行这个命令后会跳到一个vi编辑器 里面的提示有: ``` pick:保留该commit(缩写:p) reword:保留该commit,但我需要修改该commit的注释(缩写:r) edit:保留该commit, 但我要停下来修改该提交(不仅仅修改注释)(缩写:e) squash:将该commit和前一个commit合并(缩写:s) fixup:将该commit和前一个commit合并,但我不要保留该提交的注释信息(缩写:f) exec:执行shell命令(缩写:x) drop:我要丢弃该commit(缩写:d) ``` 实操 这里在终端输入: git rebase -i HEAD~2 这里的 HEAD~2 表示合并最近两次的提交, 如果想合并最近三次的提交修改为: git rebase -i HEAD~3 ![](https://img.kancloud.cn/d5/18/d51846b8555d9c6dc0d0b77f79d732f2_595x328.png) 需要做的是,将第二行的 pick 改为 s, “s” 为 “squash” 的缩写,“squash” 的意思是将这个提交压缩为最后一次提交 ![](https://img.kancloud.cn/c7/29/c72943355e74d658d7698ea5cf377c1c_595x328.png) 保存后弹出这样的 将 This is the commit message #2 下面的内容改成你想提交的概述即可 最后保存退出即可 ![](https://img.kancloud.cn/3c/a0/3ca03105d36989917626411b696d13dd_572x182.png) 2021.1.11更新 发现IDEA2020.3的版本控制可以更方便的做这个操作 ![](https://img.kancloud.cn/c9/83/c983626c7fac19df08c4783f8b337e28_698x261.png) 右键,点击Squash Commits即可