Idea 中Git使用分支合并出现合并错误(refusing to merged unrelated histories)的解决方法!

描述:首先刚到公司从公司gitlab上直接把download到了本地 在上面进行熟悉代码 更改了点东西;但是后来发现写的东西后面能用到,就想着推送到dev分支,但是推送之前要先在idea中pull到dev的代码(这个原因自查),可是发现不管是pull还是merge都会报错误refusing to merged unrelated histories,可能是它们两个版本没有关系的原因,不太清楚。

解决方法:通过查阅大量资料、验证发现一条正确方法;

1.首先打开你的git bash客户端,进入到你的项目目录,或者直接在你的项目目录中打开git bash;

然后输入git pull origin  xxx  --allow-unrelated-histories  (xxx 是远程的分支)

2.可能会报一个错误:error:“Your local changes to the following files would be overwritten by checkout”

这时有两种解决方法:

方法一、stash

1 git stash
2 git commit
3 git stash pop

接下来diff一下此文件看看自动合并的情况,并作出相应修改。

git stash: 备份当前的工作区的内容,从最近的一次提交中读取相关内容,让工作区保证和上次提交的内容一致。同时,将当前的工作区内容保存到Git栈中。
git stash pop: 从Git栈中读取最近一次保存的内容,恢复工作区的相关内容。由于可能存在多个Stash的内容,所以用栈来管理,pop会从最近的一个stash中读取内容并恢复。
git stash list: 显示Git栈内的所有备份,可以利用这个列表来决定从那个地方恢复。
git stash clear: 清空Git栈。此时使用gitg等图形化工具会发现,原来stash的哪些节点都消失了。

方法二、放弃本地修改,直接覆盖

1 git reset --hard
2 git pull origin  xxx  --allow-unrelated-histories

我用的是第二种方法;

这样就把你要合并的分支的内容合并成功。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值