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