git误操作回滚的解决方法/常用命令

 

回滚误操作的解决办法

首先用git reflog查看操作记录

和git log不同,git log可以查看提交过的版本信息,而got reflog可以查看所有分支的操作记录,包含已经被删除的commit记录。

然后git reset --hard  版本号 回滚到某版本

这部要注意首先要会推到有相关文件的提交,否则reset的时候可能会找不到文件报错。

使用git stash命令暂存代码

版本回退后,由于版本落后于gitlab上的分支项目,因此不能直接push,会报错。因此还要将你本地分支上的代码写到缓存中版存起来。(后来发现有更简单的方法,直接git push origin HEAD --force 强制推到远程分支上)

这时就可以git pull了,把远程分支拉到你的本地分支上。

然后进行git stash pop操作,把暂存的代码释放出来。这时再把本地分支的代码commit push即可。

以上是正常操作。但我在pop之后并没有发现代码合并过去了,而且git stash list竟然是空的,难道被删了?

只好用git fsck看一下,git中被删除的commit并不是真正删除,而是删除了相关的引用,然后变成了悬空对象(dangling commit)

这么多悬空对象,如何找到我想要回退的那个版本的数据?git show +对象ID 即可预览具体信息。后面那一大串是SHA1算出的hash值。找到commit之后用git stash apply还原回去就行了。

git一些常用命令

git checkout -b dev origin/dev 从远程dev分支检到新建的dev本地分支
Git branch 列出本地已经存在的分支
Git branch -r 列出远程分支
git branch -a列出本地和远程分支
git status查看仓库状态
Git commit 有三种状态:untracked未追踪状态/changes tobe commited文件已暂存/changes not updated文件被修改,但未被加入暂存区

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值