Git - 怎么把当前修改追加到前面某个commit中

怎么把当前修改追加到前面某个commit中

bash 复制代码
git log
commit b7cb11b53388d410d07e3b3084c67274cee4cdad (HEAD -> hotfix/task-108344, origin_dbackup/hotfix/task-108344)
Author: aaa <aaa@mmm.com>
Date:   Thu Mar 27 15:08:32 2025 +0800

    Fix #108344: add bbb

commit 13e6302252fc475d28431bb351155e3c2e3fde6d
Author: bbb <bbb@mmm.com>
Date:   Wed Mar 26 17:41:48 2025 +0800

    Fix #108344: add aaa

此时,我怎么把对代码的修改追加到Fix #108344: add bbb提交上,而不影响另一个提交

  1. 运行交互式 rebase
    首先,你需要运行交互式 rebase,选择一个包含你需要修改的提交范围的 commit(这里是 13e6302)
bash 复制代码
git rebase -i HEAD~2

这个命令会列出你最近的两个提交,类似这样:

bash 复制代码
pick 13e6302 Fix #108344: add aaa
pick b7cb11b Fix #108344: add bbb
  1. 修改提交
    在这个列表中,你可以看到最近的两个提交
    你需要将 13e6302 那一行的 pick 改为 edit,让 Git 在这个提交时暂停,以便你可以修改内容
    修改后,文件内容应该像这样:
bash 复制代码
edit 13e6302 Fix #108344: add aaa
pick b7cb11b Fix #108344: add bbb

保存并退出编辑器

  1. 修改代码
    Git 会暂停在 13e6302 提交,允许你修改代码
    此时,你可以修改你的代码并进行添加:
bash 复制代码
# 修改代码
git add <modified-files>
  1. 更新提交
    修改完成后,运行以下命令来更新提交:
bash 复制代码
git commit --amend --no-edit

--no-edit 选项会保持原来的提交信息不变,只更新提交的内容

  1. 继续 rebase
    提交修改完成后,运行以下命令来继续 rebase:
bash 复制代码
git rebase --continue
  1. 完成
    完成 rebase 后,检查提交历史:
bash 复制代码
git log

你会看到 13e6302 提交已经被更新,而 b7cb11b 提交保持不变

相关推荐
闲云一鹤9 小时前
Git LFS 扫盲教程 - 你不会还在用 Git 管理大文件吧?
前端·git·前端工程化
vibecoding日记3 天前
为什么我就想要「线性历史 + Signed Commits」,GitHub 却把我当猴耍 🤬🎙️
git·编程工具
程序员小崔日记4 天前
如何将代码轻松上传到 Gitee?Git 使用全攻略!
git·gitee·上传
Bigger5 天前
为什么你的 Git 提交需要签名?—— Git Commit Signing 完全指南
git·开源·github
DianSan_ERP5 天前
电商API接口全链路监控:构建坚不可摧的线上运维防线
大数据·运维·网络·人工智能·git·servlet
红豆子不相思5 天前
Tomcat 环境搭建与集群实战
服务器·git·tomcat
杰哥技术分享6 天前
Git 仓库迁移技术文档:从 CODING.net 迁移至腾讯云 CNB
git
梅孔立6 天前
Ansible 100 台服务器一键管控实战 进阶版
服务器·git·ansible
qq_426003966 天前
git切换当前分支到远程分支
git