git远程仓库版本回退

自己的分支回滚直接用reset

公共分支回滚用revert

错的太远了直接将代码全部删掉,用正确代码替代

3 本地分支版本回退的方法

如果你在本地做了错误提交,那么回退版本的方法很简单 

先用下面命令找到要回退的版本的commit id:

git reflog

接着回退版本:

git reset - - hard Obfafd

0bfafd就是你要回退的版本的commit id的前面几位

4 自己的远程分支版本回退的方法

如果你的错误提交已经推送到自己的远程分支了,那么就需要回滚远程分支了。 

首先要回退本地分支:

git reflog

git reset - - hard Obfafd

紧接着强制推送到远程分支:

git push -f

注意:本地分支回滚后,版本将落后远程分支,必须使用强制推送覆盖远程分支,否则无法推送到远程分支

使用git reset回退公共远程分支的版本后,需要其他所有人手动用远程master分支覆盖本地master分支,显然,这不是优雅的回退方法,下面我们使用另个一个命令来回退版本:

注意:

用下面这个方法可能会出现现象:结尾有解决办法,如果没遇到直接忽略

Unmerged paths:
  (use "git reset HEAD <file>..." to unstage)
  (use "git add <file>..." to mark resolution)


 

git revert HEAD                     //撤销最近一次提交

git revert HEAD~ 1                    //撤销上上次的提交,注意:数字从0开始

git revert 0f faacc                  //撤销0ffaacc这次提交

git revert 命令意思是撤销某次提交。它会产生一个新的提交,虽然代码回退了,但是版本依然是向前的,所以,当你用revert回退之后,所有人pull之后,他们的代码也自动的回退了。 

然后 git push 到远程仓库

但是,要注意以下几点:

revert 是撤销一次提交,所以后面的commit id是你需要回滚到的版本的前一次提交

使用revert HEAD是撤销最近的一次提交,如果你最近一次提交是用revert命令产生的,那么你再执行一次,就相当于撤销了上次的撤销操作,换句话说,你连续执行两次revert HEAD命令,就跟没执行是一样的

使用revert HEAD~1 表示撤销最近2次提交,这个数字是从0开始的,如果你之前撤销过产生了commi id,那么也会计算在内的。

如果使用 revert 撤销的不是最近一次提交,那么一定会有代码冲突,需要你合并代码,合并代码只需要把当前的代码全部去掉,保留之前版本的代码就可以了.

git revert 命令的好处就是不会丢掉别人的提交,即使你撤销后覆盖了别人的提交,他更新代码后,可以在本地用 reset 向前回滚,找到自己的代码,然后拉一下分支,再回来合并上去就可以找回被你覆盖的提交了。

上述现象解决办法:

是未合并的文件导致的,我是直接git add "文件名字",然后他就会自动去执行这个回退命令了,在git push 一下,你的远程仓库就会多一次提交记录,提交记录是你提交错误的上一次记录

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值