当前位置: 首页 > news >正文

【git】Git 回退到指定版本:

文章目录

        • 方法一: 使用 git reset 命令
        • 方法二:使用 git revert 命令
        • 方法三:使用 git checkout 命令
        • 常见的错误及其解决办法如下:


方法一: 使用 git reset 命令

命令可以将当前分支的 HEAD 指针指向指定的提交,从而回退代码到指定版本。
该命令有三种模式:–soft、–mixed 和 --hard。它们的区别在于回退代码的程度不同。

  1. --mixed (默认):将 HEAD 指针和暂存区都回退到指定提交,但不改变工作区的内容。
  2. --soft 仅将 HEAD 指针回退到指定提交,不改变暂存区和工作区的内容。
  3. --hard 将 HEAD 指针、暂存区和工作区都回退到指定提交,会丢失最新的代码修改,慎用。
# 查看提交历史
git log # 回退到指定提交(使用 --soft 模式)
git reset --soft <commit># 查看状态,确认回退操作是否正确
git status# 提交回退后的代码
git commit -m "回退到 <commit>"# 将修改的代码推送到远程仓库
git push origin <branch>

方法二:使用 git revert 命令

git revert 命令可以将指定提交的修改反向应用到当前分支上,相当于撤销指定提交的修改
这种方式比使用 git reset 命令更加安全,因为它不会改变提交历史,而是创建一个新的提交来撤销之前的修改。

# 查看提交历史
git log# 撤销指定提交,这样会创建一个新的提交来撤销之前的修改
git revert <commit># 提交撤销操作
git commit -m "回退到版本 <commit>"# 推送到远程仓库
git push origin <branch>

方法三:使用 git checkout 命令

git checkout 命令可以将当前分支的 HEAD 指针指向指定的提交,并将工作区的内容替换成指定提交的内容。这种方式不改变提交历史,但会直接覆盖工作区的内容,慎用

# 查看提交历史
git log# 切换到指定提交
git checkout <commit># 提交回退后的代码
git commit -m "回退到版本 <commit>"# 切回到原来的分支
git checkout <branch># 推送当前分支到远程仓库
git push origin <branch>
#<branch> 表示当前分支的名称,例如 master。这个命令会将本地分支的提交推送到远程仓库,并将远程分支更新为与本地分支一致。

常见的错误及其解决办法如下:

【1】error: failed to push some refs to ‘git@github.com:/.git’
原因:这个错误通常是由于本地分支和远程分支的提交历史不一致导致的。
解决办法:先执行 git pull 命令将远程分支的代码拉取到本地,然后再执行 git push 命令推送代码。

【2】error: src refspec does not match any
解决:这个错误通常是由于本地分支不存在或者拼写错误导致的。
解决办法:先执行 git branch 命令查看本地分支列表,确认分支名是否正确,如果不存在则需要先创建分支。

【3】error: failed to push some refs to ‘git@github.com:/.git’
解决:这个错误通常是由于权限不足导致的。
解决办法:确认当前用户是否有权限推送代码到远程仓库,如果没有则需要联系管理员进行授权。

http://www.lryc.cn/news/116723.html

相关文章:

  • kibana+nginx配置密码 ubuntu
  • Git仓关联多个远程仓路径
  • 使用ffmpeg将m4a及wav等文件转换为MP3格式
  • 【CI/CD】Git Flow 分支模型
  • SpringBoot Thymeleaf模板引擎
  • prometheus部署
  • Flink-Window详细讲解-countWindow
  • React 18 state 如同一张快照
  • EasyPoi导出 导入(带校验)简单示例 EasyExcel
  • 八大排序
  • 网络安全【黑客技术】自学
  • 【网络通信】socket编程——TCP套接字
  • ROS2系统学习番外篇2---用VSCode开发ROS2程序
  • 06 - Stream如何提高遍历集合效率?
  • 【Spring】使用注解的方式获取Bean对象(对象装配)
  • [webpack] 基本配置 (一)
  • 模板学堂|SQL数据集动态参数使用场景及功能详解
  • Wlan——射频和天线基础知识
  • 前端实习周记第三周周记
  • Android 13 Launcher界面——移除Launcher的删除和卸载功能
  • 深度学习:使用卷积神经网络CNN实现MNIST手写数字识别
  • docker search 镜像报错: connect: no route to host (桥接模式配置静态IP)
  • 【VUE】[Violation] Added non-passive event listener to a scroll-blocking...
  • runit-docker中管理多个服务
  • Intune 应用程序管理
  • Oracle DB 安全性 : TDE HSM TCPS Wallet Imperva
  • leetcode27—移除元素
  • flask---》更多查询方式/连表查询/原生sql(django-orm如何执行原生sql)/flask-sqlalchemy
  • Chromium内核浏览器编译记(三)116版本内核UI定制
  • LoRaWan网关设计架构介绍