我刚刚向错误的分支做出了完美的承诺。 我如何撤消在我的主分支中的最后一次提交,然后采取这些相同的更改,并将它们放入我的升级分支?
当前回答
如果你遇到这个问题,并且你有Visual Studio,你可以做以下事情:
右键单击分支并选择View History:
右键单击要返回的commit。并根据需要恢复或重置。
其他回答
如果你有一个干净的(未修改的)工作副本
回滚一次提交(确保你注意到了下一步的提交散列):
git reset --hard HEAD^
将该提交拉到不同的分支:
git checkout other-branch
git cherry-pick COMMIT-HASH
如果您已修改或未跟踪更改
还需要注意的是,git reset -hard会杀死你可能拥有的任何未跟踪和修改的更改,所以如果你有这些更改,你可能更喜欢:
git reset HEAD^
git checkout .
在常见的情况下,你在提交之前忘记从master切换到你的特性分支:
git checkout -B feature
git branch -f master origin/master
将origin/master替换为您希望主分支指向的提交。例如,如果您希望它指向HEAD后面的3个提交,则使用HEAD~3,如果您希望它指向带有该哈希的提交,则使用a1b2c3d。
其思想是在当前提交上重新创建特性分支并切换到它。然后使master分支指向与origin/master相同的提交。
一般情况下
在一般情况下,你想在你的特性分支上重放在master上完成的提交,如下图所示:
A---B---C---D $old_master A---B---C---D master
| \ | \
| G---H---I master <- HEAD => | G---H---I
| |
`-E---F feature `-E---F---G'--H'--I' feature <- HEAD
然后使用下面的命令在你的特性分支上选择你在master上做的提交。将$old_master替换为提交主机在进行更改之前所指向的哈希值。
git checkout feature
git cherry-pick $old_master..master
git branch -f master $old_master
如果需要,使用git stash -include-untracked隐藏你的本地更改,然后使用git stash pop取消隐藏。
不重写历史
除了选择特性分支上的更改之外,您还需要git恢复这些更改,而不是将主分支重置到过去。
git checkout feature
git cherry-pick $old_master..master
git checkout master
git revert $old_master..
git checkout feature
确保git不会将你的提交合并到特性中。如果你试图将你的特征分支合并回主分支,这些变化将被忽略,因为我们刚刚恢复了它们。
下面是结果的样子,rG, rH和rI分别是G, H和I的还原提交:
A---B---C---D rG--rH--rI master
| \ /
| G---H---I-`
|
`-E---F---G'--H'--I' feature <- HEAD
我最近做了同样的事情,当我应该提交给其他分支时,我不小心提交了一个更改给master。但我没有推动任何东西。
如果你只是提交了错误的分支,并且从那以后没有改变任何东西,也没有推送到回购,那么你可以执行以下操作:
// rewind master to point to the commit just before your most recent commit.
// this takes all changes in your most recent commit, and turns them into unstaged changes.
git reset HEAD~1
// temporarily save your unstaged changes as a commit that's not attached to any branch using git stash
// all temporary commits created with git stash are put into a stack of temporary commits.
git stash
// create other-branch (if the other branch doesn't already exist)
git branch other-branch
// checkout the other branch you should have committed to.
git checkout other-branch
// take the temporary commit you created, and apply all of those changes to the new branch.
//This also deletes the temporary commit from the stack of temp commits.
git stash pop
// add the changes you want with git add...
// re-commit your changes onto other-branch
git commit -m "some message..."
注意:在上面的例子中,我用git重置HEAD~1来重卷1提交。但如果你想倒带n次提交,你可以做git reset HEAD~n。
同样,如果你最终提交了错误的分支,并且在意识到你提交了错误的分支之前写了更多的代码,那么你可以使用git stash来保存你正在进行的工作:
// save the not-ready-to-commit work you're in the middle of
git stash
// rewind n commits
git reset HEAD~n
// stash the committed changes as a single temp commit onto the stack.
git stash
// create other-branch (if it doesn't already exist)
git branch other-branch
// checkout the other branch you should have committed to.
git checkout other-branch
// apply all the committed changes to the new branch
git stash pop
// add the changes you want with git add...
// re-commit your changes onto the new branch as a single commit.
git commit -m "some message..."
// pop the changes you were in the middle of and continue coding
git stash pop
注意:我使用这个网站作为参考 https://www.clearvision-cm.com/blog/what-to-do-when-you-commit-to-the-wrong-git-branch/
对我来说,这个问题的解决方法是恢复我之前推送的提交,然后将该提交选择到另一个分支。
git checkout branch_that_had_the_commit_originally
git revert COMMIT-HASH
git checkout branch_that_was_supposed_to_have_the_commit
git cherry pick COMMIT-HASH
您可以使用git log来找到正确的散列,并且您可以随时推送这些更改!
因此,如果你的场景是你已经提交给master,但打算提交给另一个分支(可能不存在,也可能不存在),但你还没有推送,这很容易修复。
// if your branch doesn't exist, then add the -b argument
git checkout -b another-branch
git branch --force master origin/master
现在你对master的所有提交都将在另一个分支上。
来自:http://haacked.com/archive/2015/06/29/git-migrate/
推荐文章
- 为什么我需要显式地推一个新分支?
- 如何撤消最后的git添加?
- Rubymine:如何让Git忽略Rubymine创建的.idea文件
- Gitignore二进制文件,没有扩展名
- Git隐藏错误:Git隐藏弹出并最终与合并冲突
- 了解Git和GitHub的基础知识
- 没有。Git目录的Git克隆
- Git与Mercurial仓库的互操作性
- 忽略git中修改(但未提交)的文件?
- “git restore”命令是什么?“git restore”和“git reset”之间有什么区别?
- Git合并与强制覆盖
- Git拉另一个分支
- 在Bash命令提示符上添加git分支
- 如何更改Git日志日期格式
- git pull -rebase和git pull -ff-only之间的区别