git 比较两个分支不同的commit

比如我们有 2 个分支:master, dev,现在想查看这两个 branch 的区别,有以下几种方式:

1.查看 dev 有,而 master 中没有的:

1

git log dev ^master

 同理查看 master 中有,而 dev 中没有的内容:

1

git log master ^dev

 

2.查看 dev 中比 master 中多提交了哪些内容

1

git log master..dev

 

3.不管谁提交的多谁提交的少,单纯想知道有什么不一样:

1

git log dev...master

 

4.在上述情况下,再显示出每个提交是在哪个分支上:

git log --left-right dev...master

commit 后面的箭头,根据我们在 –left-right dev…master 的顺序,左箭头 < 表示是 dev 的,右箭头 > 表示是 master的。undefined截图中表示这三个提交都是在 master 分支上的。

 原文:https://www.cnblogs.com/wentaos/p/7567502.html

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当我们在Git中合并同一个分支commit时,通是因为我们希望将多个连续的commit合并成一个更简洁的commit,以便保持代码历史的整洁性。这种情况下,我们可以使用Git提供的两种主要方法来实现。 方法一:使用交互式rebase 1. 首先,使用以下命令进入交互式rebase模式: ``` git rebase -i <commit-id> ``` 这里的`<commit-id>`是你想要合并的commit的前一个commit的ID。 2. 在弹出的文本编辑器中,将需要合并的commit前面的`pick`关键字改为`squash`或`s`。例如: ``` pick 1a2b3c4 Commit message 1 squash 5d6e7f8 Commit message 2 squash 9g0h1i2 Commit message 3 ``` 3. 保存并关闭编辑器。Git会自动打开另一个编辑器,供你编辑合并后的commit消息。 4. 编辑合并后的commit消息,保存并关闭编辑器。 5. Git会将这些commit合并为一个新的commit,并生成一个新的commit ID。 6. 最后,使用以下命令将本地分支推送到远程分支: ``` git push origin <branch-name> ``` 方法二:使用merge命令 1. 首先,使用以下命令切换到需要合并commit分支: ``` git checkout <branch-name> ``` 2. 然后,使用以下命令执行合并操作: ``` git merge --squash <commit-id> ``` 这里的`<commit-id>`是你想要合并的commit的ID。 3. Git会将这些commit合并为一个新的commit,并生成一个新的commit ID。 4. 最后,使用以下命令将本地分支推送到远程分支: ``` git push origin <branch-name> ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值