git rebase合并多个commit记录

在做一个需求的时候,会出现多次提交记录,如下:

15595@С̫□□ MINGW64 /d/project/ps-webpage (myj_beifen)
$ git log --pretty=format:'%h: %s'
03d1e8bc6: 订单修改
578639f96: 订单详情
74f2bc950: 订单详情
7d22e5fcc: 订单详情
03cacded5: [feat][1003997]:订单详情

其中,发现中间有三次提交的记录一致,是可以合并成一次commit的

下面开始合并:
1.找到要合并的commit
命令

git rebase -i  [startpoint]  [endpoint]

其中 -i 的意思是–interact,即弹出交互式的界面让用户编辑完成合并操作

[startpoint] [endpoint]是前开后闭的区间
[startpoint]是指需要合并的commit的前一个commit,在上面的例子中。[startpoint]就是03cacded5: [feat][1003997]:订单详情
[endpoint]一般是省略不写的,默认从起始的commit一直到最后一个commit,但是如果写了[endpoint],那么[endpoint]后面的commit就全都不要了,所以要慎用!

git rebase -i 03cacded5

2.进入interact交互页面
执行git rebase -i 03cacded5后,终端会进入交互页面,如下:
git rebase合并多个commit记录_第1张图片
上面红框里的,使我们筛选出来要合并的commit,是按时间顺序依次往下排序的,和git log展示的顺序是相反的
pick对应了下面红框里的commands展示第一个命令p,表示使用commit

3.使用s命令,合并commit
先按键盘 i 键,进入操作模式,把第二个和第三个commit的pick都改成s
改完之后,按 esc 键退出操作模式
然后按 :wq保存操作并退出
git rebase合并多个commit记录_第2张图片
注意:如果这里将第一个pick也改成s,则会报错
git rebase合并多个commit记录_第3张图片
git rebase合并多个commit记录_第4张图片
其中第一个s就已经给提示了,他是红色的,为什么会失败呢,是因为squash也就是s的作用是把commit合并到上一个提交,所以需要保证第一个提交是pick,出现这种情况的话,就执行

git rebase --abort

重来一次,这样最稳妥。
点击了解,git rebase --abort

4.修改commit记录
如果第三步成功后,接下来会弹出下面这个页面,分别展示了三个commit的提交信息
git rebase合并多个commit记录_第5张图片
我们只需要把第二条和第三条的信息注释掉即可,即按i 键,在第二个和第三个订单详情前面加#号,然后按 esc,最后:wq保存即可
git rebase合并多个commit记录_第6张图片
5.查看最新合并情况
执行 git log --pretty=format:‘%h: %s’,发现之前的三次commit合并成了一次commit,成功!
git rebase合并多个commit记录_第7张图片
扩展:

命令 缩写 用法
pick p 保留该commit
reword r2 保留该commit,但需要修改该commit的注释
edit e 保留该commit, 但我要停下来修改该提交(不仅仅修改注释)
squash s 将该commit合并到前一个commit
fixup f 将该commit合并到前一个commit,但不要保留该提交的注释信息
exec e 执行shell命令
drop d 丢弃该commit

你可能感兴趣的:(git,git,合并commit,git,rebase)