两种情况(场景)


情况一  
    代码还只在本地,未push到运程仓库,想把代码还原到上一次commit的代码,此时操作为代码撤销

解决方案:

1
git reset [--hard|soft|mixed|merge|keep] [commit|HEAD]

情况二
    代码已经push到运程仓库,想把代码还原到上一次提交,此时操作为代码回滚

解决方案:

1)查看git提交日志,找到上次提交的信息,输入命令 git log (查看全部日志)或 git log -xx(查看最近xx条日志)

  1. $ git log -3
  2.  
  3. commit 4dc08bb8996a6ee02f
  4. Author: Mark <xxx@xx.com>
  5. Date: Wed Sep 7 08:08:53 2016 +0800
  6.  
  7. xxxxx
  8.  
  9. commit 9cac9ba76574da2167
  10. Author: xxx<xx@qq.com>
  11. Date: Tue Sep 6 22:18:59 2016 +0800
  12.  
  13. improved the requst
  14.  
  15. commit e377f60e28c8b84158
  16. Author: xxx<xxx@qq.com>
  17. Date: Tue Sep 6 14:42:44 2016 +0800
  18.  
  19. changed the password from empty to max123

可以看到,我标红的就是commit的ID标识,所以为了更好区分你每次代码提交标识,建议每次提交时给到Tag(提交信息)。

2)回滚到指定的版本(hard后面接的是上面标红的ID,也就是想回滚到的版本)

1
2
3
4
5
## 回退到指定版本,不保留原更改代码
git reset --hard e377f60e28c8b84158
 
## 回退到指定版本,保留原更改代码,且生成新的提交
git revert e377f60e28c8b84158     

  

3)强制提交(这个时候已经将代码回退了,你现在的分支状态就处于你上一步指向的版本)

1
git push -f origin master

4)如果你只是误提了代码,想保留代码改动的话,那就在2)的时候使用revert 命令,而不是reset,两者区别如下:

  • revert 是放弃指定提交的修改,但是会生成一次新的提交,需要填写提交注释,以前的历史记录都在;
  • reset是指将HEAD指针指到指定提交,历史记录中不会出现放弃的提交记录。

  1. 关于对Gitreset详解,可以参考:https://www.jianshu.com/p/12803dba313e

补充场景:误将其他分支代码合到自己分支且代码已提交到远端

思路

先将代码回滚到上一次提交,这样原本提交到远端的代码就会被撤销并在本地重新生成一次提交,接着将想提交的代码修改完后,暂存到本地存起来,接着切换到主分支将主分支代码拉下来保持其代码一致,随后删除掉原本提交代码的分支,重新新建一个分支,接着将原本暂存的代码拿出来,提交到新分支上,结束!  

解决步骤

1
2
3
4
5
6
7
8
9
10
git status                    查看当前分支状态
git log                       查看提交历史
git reset  ***              根据提交历史ID回滚代码至上一次提交(参考上文)
git stash                     将回滚后的代码,暂存到本地仓库
git checkout master        将当前分支切换至master主分支
git pull                      将master的代码拉至本地,保持当前代码是正式环境运行代码
git branch -d ***(原本提交代码的分支名)  删除本地原分支
git checkout -b ***          新建一个新的分支且切到分支上
git stash pop                将暂存至本地仓库的代码取出来
git push --force             将代码强制发布

[转]Git 代码撤销、回滚到任意版本(当误提代码到本地或master分支时)的更多相关文章

  1. git回滚到任意版本

    git回滚到任意版本 先显示提交的log $ git log -3 commit 4dc08bb8996a6ee02f Author: Mark <xxx@xx.com> Date: We ...

  2. git 回滚到任意版本

    git回滚到任意版本 1.先显示提交的log $ git log -3 commit 4dc08bb8996a6ee02f Author: Mark <xxx@xx.com> Date: ...

  3. Git 代码撤销、回滚到任意版本(当误提代码到本地或master分支时)

    转自https://www.cnblogs.com/lwh-note/p/9639835.html 两种情况(场景) 情况一      代码还只在本地,未push到运程仓库,想把代码还原到上一次com ...

  4. android开发学习 ------- git - 将代码回滚到任意版本

    不小心将一个东西错误提交到git - 远程仓库上 参考  https://www.cnblogs.com/wancy86/p/5848024.html 你的git可能关联了多个远程仓库,每个关联的代码 ...

  5. git回滚到任意一个版本

    1.首先查找提交的记录(-3表示显示最近的3条) git log -3 2.强制回滚到制定版本 git reset --hard 制定版本commitId 如:git reset --hard 4ba ...

  6. git回滚到某个版本操作

    git回滚到某个版本操作: 1.git log //查看指过去的版本 2.     git reset --hard 复制上面commit后的字符串到此处 如果只想 回滚单机的,那么到上面就结束,如果 ...

  7. git:GitLab代码回滚到特定版本

    在当前branch上多次commit代码并且push后,发现不符合要求,需要回滚到特定的版本.步骤如下: 1.查找commitId (1)用命令行打开git项目路径,输入git log命令查看comm ...

  8. git 回滚到某个版本

    首先使用git log 显示最近的代码提交记录 commit后面的内容,就是回滚的记录名 增加了加载条显示,提高用户体验 commit 47f45668e72e4deeccae85e9767c250d ...

  9. svn 回滚到某个版本

    用svn merge命令来进行回滚. 回滚的操作过程如下: 1.保证我们拿到的是最新代码: svn update 假设最新版本号是28. 2.然后找出要回滚的确切版本号: svn log 假设根据sv ...

随机推荐

  1. 修改ActiveMQ的内存大小

    有时我们需要修改ActiveMQ的内存大小,防止内存溢出! 修改配置文件下-Xmx参数然后重启mq即可: /fs01/apache-activemq-5.15.0/bin/env ACTIVEMQ_O ...

  2. java8 lamb表达式对List排序

    场景一:List<Long> 或其他泛型,非对象 List<Long> ids = new ArrayList(); ids.add(100000001L); ids.add( ...

  3. Maven简易笔记

    Maven笔记 Maven笔记 Maven组成 安装配置 基本概念 Maven目录的典型结构 POM文件格式 GAV 依赖 依赖管理与父项目 关于父项目的一点主意事项 repository Maven ...

  4. server端和前端的区别

    1.服务稳定性 server端可能会遭受各种恶意攻击和误操作 单个客户端可以意外挂掉,但是服务端不能 node中用pm2做进程守候,一旦挂掉,自己会重启 2.考虑内存和cpu(优化,扩展) 客户端独占 ...

  5. spark context stop use with as

    调用方法: with session.SparkStreamingSession('CC_Traffic_Realtime', ssc_time_windown) as ss_session: kaf ...

  6. P1600 天天爱跑步[桶+LCA+树上差分]

    题目描述 小c同学认为跑步非常有趣,于是决定制作一款叫做<天天爱跑步>的游戏.<天天爱跑步>是一个养成类游戏,需要玩家每天按时上线,完成打卡任务. 这个游戏的地图可以看作一一棵 ...

  7. go http编程

    http的请求包包含 请求行,请求头,空行,请求体go的http编程 http server.go package main import "net/http" func main ...

  8. 0.0.Pycharm使用技巧

    调整自动字体大小 Increase(字体变大) Decrease(字体变小) 背景颜色设置 pycharm 左侧菜单问题 解决 pycharm中配置启动Django项目 1.先打开mange.py,然 ...

  9. nowcoder73E 白兔的刁难 单位根反演+NTT

    感觉很套路? #include <bits/stdc++.h> #define ll long long #define setIO(s) freopen(s".in" ...

  10. QtWebEngineWidgets

    我用的qt5.10+VS2017,2013应该一样项目属性里手动添加包含目录:(QTDIR)\include\QtWebEngineWidgets,(QTDIR)\include\QtWebChann ...