⛔️⛔️⛔️丢弃本地commit,强制采用远端代码

你可以使用以下命令将本地所有的 commit 丢弃,并强制采用远端的代码(注意:这会丢弃本地的未push的所有改动,无法恢复),建议你明白自己在干什么,并且已经备份了本地代码(建议使用history插件进行代码备份)的情况下才可以使用。


✅ 方法一:强制重置为远端状态

sql 复制代码
git fetch origin
git reset --hard origin/你的分支名

例如你当前在 main 分支:

css 复制代码
git reset --hard origin/main

🔥 说明:

  • git fetch origin:拉取远端分支信息(不合并)
  • git reset --hard origin/main:把当前分支重置为远端分支状态,本地的提交和修改都会被丢弃

✅ 方法二(如果你还未 push 本地 commit,可直接放弃提交历史):

css 复制代码
git reset --hard HEAD~N
  • HEAD~N 表示回退 N 个 commit
  • 这适用于你只想撤销最后几次提交,不涉及远端对比

✅ 方法三(重建分支,彻底从远端拷贝):

如果你想完全重置当前分支为远端版本,也可以删除再重新 checkout:

perl 复制代码
git checkout your-branch-name
git branch -D temp-reset
git checkout -b temp-reset origin/your-branch-name

或者:

bash 复制代码
git checkout -B your-branch-name origin/your-branch-name

这将创建并强制覆盖本地分支为远端分支状态。


⚠️ 注意事项

  • 这些操作都 不可逆,执行前请确保你不再需要本地 commit。

  • 如需备份本地改动,可先执行:

    git branch backup-branch

相关推荐
SNOWPIAOP34 分钟前
git status 出现中文乱码的解决方案等
git·乱码·postgres
qq_4352879211 小时前
第9章 夸父逐日与后羿射日:死循环与进程终止?十个太阳同时值班的并行冲突
java·开发语言·git·死循环·进程终止·并行冲突·夸父逐日
AIMath~18 小时前
Git 子模块(Submodule)目录结构清除实战复盘
git
切糕师学AI19 小时前
Ubuntu 下 Git 完全使用指南
linux·git·ubuntu
一袋米扛几楼9820 小时前
【Git】规范化协作:详解 GitHub 工作流中的 Issue、Branch 与 Pull Request 最佳实践
前端·git·github·issue
尘埃落定wf21 小时前
# GitHub CLI:告别繁琐的 Git 命令,让开发更高效
git·github
恋喵大鲤鱼21 小时前
git clone
git·git clone
金牛IT1 天前
Gogs 轻量级 Git 服务器搭建与使用
运维·服务器·git
Qres8211 天前
Git安装记录
git
wj3055853781 天前
Codex + Git 开发环境配置指南(WSL版)
linux·运维·git