关于git分支间合并

git分支间合并

今天遇到一个需求,因为业务原因,现已开发的部分功能,暂时不上线,只上线部分功能,但我们的所有功能都在同一个分支上,于是就需要把部分功能代码分离出来,一起来看看吧!

一、合并单个commit

首先,我们需要把A分支上提交的部分代码,放在B分支上

git checkout B  // 切换到B分支
git cherry-pick 43aea9af  // 把某一次的commit合并到B分支,其中’43aea9af‘是某次commit提交记录的ID
git push origin B  // 把分支B推送到远程仓库

二、合并连续的多个commit

如果我们想要合并多个连续的commit,用上面的第一种方法,显然效率不高,可以使用一下方法:
比如我们再A分支上有43aea9af到70dfeec2a的连续的10个commit要合并到B分支上

首先基于A分支创建一个临时分支temp,并指明新分支的最后一个commit

git checkout -b temp 70dfeec2a

将temp分支上的从43aea9af到最后一个commit,也就是70dfeec2a的commit合并到B分支上

git rebase --into B 43aea9af^

三、合并两个完整的分支

假如我们现在在dev分支上,刚开发完项目,执行了下列命令:

git  add .
git  commit -m '提交的备注信息'
git  push -u origin dev

想将dev分支合并到master分支,操作如下:

1、首先切换到master分支上

git  checkout master

2、如果是多人开发的话 需要把远程master上的代码pull下来

git pull origin master

//如果是自己一个开发就没有必要了,为了保险期间还是pull
3、然后我们把dev分支的代码合并到master上

git  merge dev

4、然后查看状态及执行提交命令

git status

On branch master
Your branch is ahead of ‘origin/master’ by 12 commits.
(use “git push” to publish your local commits)
nothing to commit, working tree clean

​//上面的意思就是你有12个commit,需要push到远程master上

最后执行下面提交命令

git push origin master
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值