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

回滚误操作的解决办法

之前没用过git,有一次在commit本地代码后,还没有push上去,不小心回滚到了之前的版本,代码全丢了。下面记一下解决方法:

首先用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文件被修改,但未被加入暂存区

  • 8
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
回滚git的步骤可以分为三步。首先,在idea中使用git插件找到要回滚的分支,右键点击"Rest current branch to Hera"来进行重置。这是第一步。接着,选中项目并右键选择git,再选择"Rollback"来回滚变动的代码。需要注意的是,如果有新建的文件或改动的代码需要回滚,需要手动删除这些文件,以避免误提交。这是第二步。 最后,使用git命令界面进入git bash界面,并使用命令"$ git push --force origin 分支"来强制提交回滚后的代码。记得在提交前,让自己电脑上pull过本分支代码的同学删除本地分支,以避免其他同学提交时仍然提交合并回滚前的代码。 所以,回滚git的步骤为: 1. 在idea中找到要回滚的分支,右键点击"Rest current branch to Hera"进行重置。 2. 选中项目并右键选择git,再选择"Rollback"回滚变动的代码。 3. 使用git命令界面进入git bash界面,并使用命令"$ git push --force origin 分支"强制提交回滚后的代码。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Idea开发工具操作git回滚提交步骤](https://blog.csdn.net/u010132847/article/details/126689209)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [idea中git代码回滚](https://blog.csdn.net/xiaowanzi_zj/article/details/121369164)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值