使用git reset 合并只有两个commit到一个

这个是一个同事让我把他的repository若干个commit变成一个,我用git rebase -i合并到最后发现剩下只有两个commit的时候,git rebase -i不再起作用,于是我求助了git maillist,果然很快有人给出了答案:

git reset --soft HEAD^1
git commit --amend
esc
:wq

最后

git push --force origin master

master为对应分支名字



扫码领取红包


支持我的人可以扫描二维码领取红包,右边可以向我打款表示支持。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
git reset和rebase是git版本控制中的两个重要命令,用于管理代码提交和修改历史。 git reset命令用于将当前分支的HEAD指针移动到指定的提交,同时可选择性地修改工作目录和暂存区的文件状态。它有三种常用的模式: 1. Soft Reset使用`git reset --soft <commit>`可以将HEAD指针移动到指定提交,但不修改工作目录和暂存区的文件。这意味着之前的提交会被撤销,但相应的更改会保留在暂存区,可以重新提交。 2. Mixed Reset使用`git reset --mixed <commit>`是默认的reset模式,它将HEAD指针移动到指定提交,并且重置暂存区,但不修改工作目录的文件。这意味着之前的提交和相应的更改都会被撤销,并且文件状态会回到最近一次提交的状态。 3. Hard Reset使用`git reset --hard <commit>`会彻底重置当前分支的HEAD指针、暂存区和工作目录到指定提交。这意味着之前的提交和相应的更改都会被彻底删除,请谨慎使用git rebase命令用于在当前分支上应用另一个分支上的提交,并将其追加到当前分支的提交历史中。它可以实现分支合并的效果,但是与git merge命令不同,rebase会修改提交历史,使得分支合并后的提交看起来更加线性和整洁。 使用`git rebase <branch>`可以将当前分支的提交应用到指定的分支上,也可以使用交互式(rebase -i)的方式对提交进行修改、合并或删除。 需要注意的是,使用git reset和rebase命令都会修改提交历史,所以在公共分支上使用时要谨慎,以免影响其他开发者的工作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值