Git命令之本地分支与远程分支支关联/解除关联

1.应用场景

在实际的工作生活中,往往需要将本地的分支和远程分支关联,这样我们就可以使用git pull命令来更新拉取最新的代码,并使用git push命令将自己本地的修改推送到远程仓库。但是如果此时你本地关联的远程分支被删除了,那么就会出现你无法使用git pull,和git push命令。使用一个例子说明这个场景。 我们可以使用下面的命令查看自己本地分支与与远程分支的关联情况:

kotlin 复制代码
git branch -vv

如上图所示,我们可以看到本地的master分支和远程的origin/master分支关联,nololibs_for_git 和远程的origin/nololibs_release 关联。 这时候假设我们将远程分支origin/nololibs_release删掉,这时候我们执行git pull命令就会报错,如下所示: 意思就是我们之前关联的远程分支不存在了。

2.关联远程仓库中存在的分支

要解决git pull报错的问题就需要我们重新关联一个远程仓库中存在的分支。这时候假设远程仓库中有 一个分支为origin/nololibs_for_git,我们只需要执行下面的命令:

kotlin 复制代码
git branch -u 远程分支名
// 例如:git branch -u origin/nololibs_for_git

也可以使用下面的命令关联远程分支:

kotlin 复制代码
git branch --set-upstream-to 远程分支名
//例如: git branch --set-upstream-to origin/nololibs_for_maven

执行完上面的命令后,我们可以使用git branch -vv 查看下当前的本地分支和远程分支的关联情况: 我们可以发现本地分支nololibs_for_git和远程分支origin/nololibs_for_git以及关联上了。

3.解除本地分支与远程分支的关联

比如我们有时候会想将远程分支改个名字啥的,或者就是单纯想解除与远程分支的关联,这时候可以使用下面的命令解除本地分支与远程分支的关联:

kotlin 复制代码
git branch --unset-upstream

例如:假设现在我想解除本地的nololibs_for_git和远程的origin/nololibs_for_git的关联。 首先先用git branch -vv 命令看下分支的关联情况: 可以发现本地的nololibs_for_git和远程的origin/nololibs_for_git是关联着的,这时我们执行命令git branch --unset-upstream,再使用git branch -vv命令查看分支关联情况。 可以看到只有本地的分支了,远程的分支以及没有了,这时候使用git pull命令会提示关联远程分支 这时候我们再执行关联远程分支的命令git branch -u 远程分支名 就可以使用了。

相关推荐
阿巴~阿巴~11 小时前
Git 删除文件
git·gitee·github
花椒和蕊17 小时前
记录git报错ssh: connect to host github.com port 22: Connection timed out,已解决
git·ssh·github
wayhome在哪20 小时前
Git 合并:Merge 还是 Rebase?
git·面试·github
自动花钱机2 天前
Cherry-pick冲突与Git回滚
git
coderklaus2 天前
git rebase
git
苏元2 天前
☠️ 写错 commit = 绩效自爆,别说我没提醒你!
git
程序设计实验室2 天前
模型文件硬塞进 Git,GitHub 直接打回原形:使用Git-LFS管理大文件
git
Dontla3 天前
脚本:git push直到成功(windows powershell命令)(Github连不上、Github断开)
git·github
CAE虚拟与现实3 天前
GitHub Desktop 和 Git 命令行工具(CLI)各有优势
git·github·github desktop
RePeaT3 天前
代码双仓库备份指南:三种简单高效的方法
git·github