git如何从某个分支的指定历史版本中创建新分支

 更新时间:2023年05月26日 10:07:07   作者:YadingLee  
这篇文章主要介绍了git如何从某个分支的指定历史版本中创建新分支问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

git从某个分支的指定历史版本中创建新分支

有时候,我们在一个分支上做了许多修改,而这些修改因即将上线等原因不可修改。

而现在有一个新任务,需要在这个分支的这些修改之前进行开发。

方案①(不推荐):在这些分支上撤销这些修改的内容,再进行开发 

方案②(推荐):从当前分支的某个历史版本中切出新的分支进行开发

具体操作

1.查看历史版本

git log

2.从提交的某个历史版本中切出新分支

比如:从切到测试环境(780e2a7fc714faf388ba71)这个历史节点切出

git checkout -b new-branch 780e2a7fc714faf388ba71

经过以上步骤,您已经从指定分支的指定历史版本创建出了一个新分支

git在某个节点切出新分支

操作前,必须先备份分支,避免丢失代码!!!!

 操作前,必须先备份分支,避免丢失代码!!!!  

操作前,必须先备份分支,避免丢失代码!!!!

找到节点编号

使用 git log 命令查看提交记录

或者使用IDEA找提交记录

从当前提交 HEAD 指针创建一个临时未命名分支

git chekcout 91d38bf2

这个时候只是从这个节点创建了一个临时未命名分支,

如果你这个时候切换到别得分支,那么你就相当于放弃了这个未命名分支

把临时分支保留的提交创建成新分支

git switch -c 2023-0306-dev

成功从develop 的 head: 91d38bf2(某次提交) 切出一个新的分支

推送到远程并与远程的2023-0306-dev关联 (若没有远程分支创建并关联)

git push -u origin 2023-0306-dev

应用场景

合并错误分支 

需要发布某一节点的分支

紧急发布        

  • 开发过程中,本次代码已经全部合并到dev(测试中待发布状态)
  • 这时有个紧急bug需要修复,但是不能把本待发布的版本发上去
  • 找到上次发布节点,切出新分支,更改bug,快速发布

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • windows下Idea使用git clone failed. Could not read from remote repository.

    windows下Idea使用git clone failed. Could not read from remote r

    这篇文章主要介绍了windows下Idea使用git clone failed. Could not read from remote repository.,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-09-09
  • 日历控件和天气使用分享

    日历控件和天气使用分享

    本文给大家分享的2个简单而且实用的小功能代码,分别是日历控件和天气预报接口,推荐给大家,需要的小伙伴快来参考下吧
    2015-03-03
  • 微信 小程序开发环境搭建详细介绍

    微信 小程序开发环境搭建详细介绍

    这篇文章主要介绍了微信 小程序开发环境搭建详细介绍的相关资料,需要的朋友可以参考下
    2016-09-09
  • Web开发人员常用速查手册 英文集合推荐

    Web开发人员常用速查手册 英文集合推荐

    不管你是多么优秀的程序员,你都不可能记住一切。在你编写程序的过程中碰到问题需要查阅手册的时候,若有现成的手册可参考则可以为你节省很多时间。
    2011-04-04
  • 分享几道和「滑动窗口」有关的算法面试题

    分享几道和「滑动窗口」有关的算法面试题

    本文是小编和大家分享的几道和「滑动窗口」有关的算法面试题,需要的朋友可以参考下
    2019-08-08
  • git-github 子模块仓库更新(git submodule)及git中submodule子模块的添加、使用和删除操作

    git-github 子模块仓库更新(git submodule)及git中submodule子模块

    这篇文章主要介绍了git-github 子模块仓库更新(git submodule)/git中submodule子模块的添加、使用和删除,使用子模块后,不必负责子模块的维护,只需要在必要的时候同步更新子模块即可,需要的朋友可以参考下
    2023-03-03
  • idea+git合并分支解决冲突及详解步骤

    idea+git合并分支解决冲突及详解步骤

    这篇文章主要介绍了idea+git合并分支解决冲突及详解步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-07-07
  • HTTPS的七个误解

    HTTPS的七个误解

    这篇文章主要介绍了HTTPS的七个误解,需要的朋友可以参考下
    2015-04-04
  • 如何让Visual Studio用上chatgpt

    如何让Visual Studio用上chatgpt

    这篇文章主要介绍了如何让Visual Studio用上chatgpt,Visual chatGPT Studio是Visual Studio的一个免费扩展,它直接在IDE中添加了chatGPT功能,它允许用户以可以根据菜单功能的方式使用chatGPT,需要的朋友可以参考下
    2023-05-05
  • vscode配置setting.json文件实现eslint自动格式代码

    vscode配置setting.json文件实现eslint自动格式代码

    这篇文章主要介绍了vscode配置setting.json文件实现eslint自动格式代码,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-08-08

最新评论