git 推错东西到仓库,怎么删记录跟没发生事情一样

Git 撤销提交的两种方法:git resetgit rebase

在 Git 中,撤销提交是一个常见的操作,尤其是在提交了错误的代码或信息时。本文将介绍两种常用的撤销提交方法:git resetgit rebase,并通过实际场景演示如何使用它们。

1. 使用 git reset 撤销提交

1.1 作用

git reset 用于移动 HEAD 指针并可选地更改暂存区和工作目录的状态。它常用于撤销提交、取消暂存文件、修改提交内容等操作。

1.2 语法

1.2.1 撤销提交,保留修改
bash 复制代码
git reset --soft HEAD~1
  • 作用:撤销最新的提交,但保留所有更改在工作目录中。你可以重新提交并修改提交信息。
  • 适用场景:当你想要修改提交信息或重新组织提交内容时。
1.2.2 撤销提交,取消暂存的文件
bash 复制代码
git reset HEAD~1
  • 作用:撤销最新的提交,并将暂存区的文件取消暂存,但保留在工作目录中。
  • 适用场景:当你想要重新选择要暂存的文件时。
1.2.3 撤销提交,丢弃修改
bash 复制代码
git reset --hard HEAD~1
  • 作用:撤销最新的提交,并丢弃所有更改,包括暂存区和工作目录中的文件。
  • 适用场景:当你想要完全回到上一个提交的状态时。
1.2.4 将 HEAD 指针移动到指定的提交
bash 复制代码
git reset --hard <commit-hash>
  • 作用:将 HEAD 指针移动到指定的提交,并丢弃所有更改。
  • 适用场景:当你想要回滚到历史提交状态时。

1.3 撤销实操

假设你误操作提交了两次错误的记录,现在想要撤销这些提交。

1.3.1 撤销最近两次提交
bash 复制代码
git reset HEAD~2
  • 作用:将 HEAD 指针移动到前两次提交之前的状态,保留工作目录中的更改。
  • 结果:本地代码恢复到没有提交这两个记录前的状态。
1.3.2 强制推送到远程仓库
bash 复制代码
git push --force
  • 作用:将本地仓库的状态强制推送到远程仓库,覆盖远程仓库的提交历史。
  • 注意:这是一个危险的操作,确保本地代码和远程代码是相关的。

1.4 重要提示

  • 使用 --force 选项会覆盖远程仓库的提交历史,确保你了解其风险。
  • git push --forcegit push origin <branch-name> --force 的简写。

2. 使用 git rebase 撤销提交

2.1 场景复现

假设你有以下三个提交记录:

bash 复制代码
commit def5adef853da4cc05752bdb36577c127be71ba5
Author: xxx
Date:   Thu Dec 28 16:01:36 2017 +0800
优化代码

commit 853dadef5adef4cc05752bdb36577c127be71ba5
Author: xxx
Date:   Thu Dec 28 16:01:36 2017 +0800
增加文件

commit f36801544670e00b2f59a28e19017d2786c4085e
Author: xxx
Date:   Thu Dec 28 15:59:46 2017 +0800
修复

现在你不需要第二个提交(即"增加文件"这个操作),想要将其从提交历史中删除。

2.2 使用 git rebase 删除指定提交

2.2.1 使用 git rebase --onto
bash 复制代码
git rebase --onto master~2 master~1 master
  • 作用 :将 master 分支从第二个提交(853dade)开始的部分重新基于第一个提交(f368015)之上,从而删除第二个提交。
  • 结果:提交历史中将不再包含"增加文件"这个提交。
2.2.2 使用 git rebase -i
bash 复制代码
git rebase -i f368015
  • 作用 :进入交互式 rebase 模式,将需要删除的提交前面的 pick 改为 drop,然后保存退出。
  • 结果:提交历史中将不再包含"增加文件"这个提交。

2.3 强制推送到远程仓库

bash 复制代码
git push --force
  • 作用:将本地仓库的状态强制推送到远程仓库,覆盖远程仓库的提交历史。
  • 注意:这是一个危险的操作,确保本地代码和远程代码是相关的。

2.4 修改提交的 Author

如果你只是想修改某个提交的 Author 信息,可以使用以下命令:

bash 复制代码
git rebase -i f368015
  • 步骤
    1. 将需要修改的提交前面的 pick 改为 edit
    2. 执行 git commit --amend --author="新的作者信息"
    3. 执行 git rebase --continue 完成 rebase 过程。

总结

  • git reset:适合撤销最近的提交,尤其是当你想要保留或丢弃工作目录中的更改时。
  • git rebase:适合删除或修改历史提交,尤其是当你想要删除某个特定的提交时。

无论使用哪种方法,强制推送(git push --force)都是一个危险的操作,务必谨慎使用。

相关推荐
Z兽兽4 小时前
React@18+Vite项目配置env文件
前端·react.js·前端框架
SuniaWang4 小时前
《Spring AI + 大模型全栈实战》学习手册系列 · 专题六:《Vue3 前端开发实战:打造企业级 RAG 问答界面》
java·前端·人工智能·spring boot·后端·spring·架构
A_nanda4 小时前
根据AI提示排查vue前端项目
前端·javascript·vue.js
happymaker06265 小时前
web前端学习日记——DAY05(定位、浮动、视频音频播放)
前端·学习·音视频
~无忧花开~5 小时前
React状态管理完全指南
开发语言·前端·javascript·react.js·前端框架
LegendNoTitle5 小时前
计算机三级等级考试 网络技术 选择题考点详细梳理
服务器·前端·经验分享·笔记·php
@大迁世界6 小时前
1.什么是 ReactJS?
前端·javascript·react.js·前端框架·ecmascript
BJ-Giser6 小时前
Cesium 基于EZ-Tree的植被效果
前端·可视化·cesium
王码码20357 小时前
Flutter for OpenHarmony:Flutter 三方库 algoliasearch 毫秒级云端搜索体验(云原生搜索引擎)
android·前端·git·flutter·搜索引擎·云原生·harmonyos
发现一只大呆瓜7 小时前
深入浅出 AST:解密 Vite、Babel编译的底层“黑盒”
前端·面试·vite