Git push后撤销提交

一、介绍

        当某次更改完工程后,push了本地仓库到云端,但是发现有地方改错了,想撤销这次推送,或者某次提交就更改了很小一部分,想和本地这次修改的合并为一次推送,省的在云端显示特别多次提交,显得非常乱。

二、命令

1. 首先通过git log --oneline命令查看之前的提交信息

git log --oneline

2. 使用git reset命令回退,--soft会保留本地更改,--hard不会保留本地更改

 意思就是如果你本地更改了,最好用--soft,因为他会保留你现在的更改,如果使用了--hard,他会直接把你本地更改覆盖,直接退回你填写的ID那个版本

git reset --soft 要回退到哪次提交的ID

3. 再次使用git log --oneline命令查看,发现在你填写的回退ID版本之后的提交都没了

4.更改完成后,在使用git add 和 git commit 重新提交本地仓库

5.将本次提交强制推动到云端仓库,一定要加--force,不然是推送不上去的

git push origin 分支名 --force

这时候发现云端仓库还是显示一次提交,相当于你撤销了上一次提交,只提交了本次,但是云端可以看出来这次提交是强制提交 

这种不仅能撤回一次提交,根据你写的要回退版本的ID来的,你ID写的哪个版本,就会在那个版本的基础上多一次提交。

        

        

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值