git创建新分支、合并分支、回滚分支常用命令

Git常用命令操作

  1. 创建本地分支、同步远程分支
  2. 合并分支、推送到远程分支
  3. 将其他分支的某一次提交合并到当前分支
  4. 回滚分支、将当前分支回滚到某一次提交
  5. 撤销本次修改、放弃本次提交
  6. 将本次修改暂存起开,顺利切换分支后 在任意分支将暂存取出

1、创建本地分支、同步远程分支

先切到基础分支,基于这个分支创建一个新分支
# smt @ Smt-MacPro in /Volumes/code/www/ups-api on git:master o [11:29:39] 
$ git checkout -b dala_2.9.0
Switched to a new branch 'dala_2.9.0'

创建完直接推送到远程会提示让先绑定远程分支,直接使用提示得命令绑定即可
# smt @ Smt-MacPro in /Volumes/code/www/ups-api on git:dala_2.9.0 o [11:29:56] 
$ git push   
fatal: The current branch dala_2.9.0 has no upstream branch.
To push the current branch and set the remote as upstream, use

    git push --set-upstream origin dala_2.9.0

绑定远程分支
# smt @ Smt-MacPro in /Volumes/code/www/ups-api on git:dala_2.9.0 o [11:30:46] C:128
$ git push --set-upstream origin dala_2.9.0 
Total 0 (delta 0), reused 0 (delta 0)
remote: Processing changes: done    
remote: Updating references: 100% (1/1)
To git.code.tencent.com:ups/ups-api.git
 * [new branch]          dala_2.9.0 -> dala_2.9.0
Branch 'dala_2.9.0' set up to track remote branch 'dala_2.9.0' from 'origin'.

推送分支
# smt @ Smt-MacPro in /Volumes/code/www/ups-api on git:dala_2.9.0 o [11:31:45] 
$ git push
Everything up-to-date

---------------------------------------------------------------------

// 删除远程分支
$ git push origin --delete dala_bug
remote: Processing changes: done    
remote: Updating references: 100% (1/1)
To git.code.tencent.com:ups/ups-api.git
 - [deleted]           dala_bug
 
// 删除本地分支
$ git branch -d dala_bug


2、合并分支、推送到远程分支:
要将 B 分支合并到 A 分支,要先将当前分支切换到 A 分支,然后将B分支合并过来,再推送到远程分支

// 先切换到 A 分支
$ git checkout A 
Switched to branch 'A'

// 多人开发时 可能有其他人提交到这个分支,所以要先拉取,有冲突先解决冲突
$ git pull

// 将B分支合并到A分支 
$ git merge B 

// 将合并完的代码推送到远程A分支
$ git push


3、 将其他分支的某一次提交合并到当前分支:
要将 A 分支的一个 commit 合并到 B 分支


// 先切换到 A 分支
$ git checkout A
// 查看日志 找到要合并的提交 commit ID 
$ git log

//例如
1898660c08e325d410cb845616af355c0c145j9f

// 然后切换到 B 分支上
$ git checkout B

// 之心合并命令( git cherry-pick )跟上其他分支的提交id
$ git cherry-pick  1898660c08e325d410cb845616af355c0c145j9f


4、 回滚分支、将当前分支回滚到某一次提交:

1、回退命令:

// 回退到上个版本
$ git reset --hard HEAD^

// 回退到前2次提交之前,以此类推,回退到n次提交之前
$ git reset --hard HEAD~2

// 退到/进到 指定commit的sha码
$ git reset --hard commit_id

2、强推到远程:(--force 是参数,不是仓库名)
$ git push origin HEAD --force

5、 撤销本次修改、放弃本次提交:

// 未添加至暂存区的
git checkout .

// 已添加至暂存区的
git reset HEAD .
git checkout .

5、将本次修改暂存起开,顺利切换分支后 在任意分支将暂存取出:


常用git stash命令:

(1)git stash save "save message"  : 执行存储时,添加备注,方便查找,只有git stash 也要可以的,但查找时不方便识别。

(2)git stash list  :查看stash了哪些存储

(3)git stash show :显示做了哪些改动,默认show第一个存储,如果要显示其他存贮,后面加stash@{$num},比如第二个 git stash show stash@{1}4)git stash show -p : 显示第一个存储的改动,如果想显示其他存存储,命令:git stash show  stash@{$num}  -p ,比如第二个:git stash show  stash@{1}  -p

(5)git stash apply : 应用某个存储,但不会把存储从存储列表中删除,默认使用第一个存储,即stash@{0},如果要使用其他个,git stash apply stash@{$num} , 比如第二个:git stash apply stash@{1}6)git stash pop :命令恢复之前缓存的工作目录,将缓存堆栈中的对应stash删除,并将对应修改应用到当前的工作目录下,默认为第一个stash,即stash@{0},如果要应用并删除其他stash,命令:git stash pop stash@{$num} ,比如应用并删除第二个:git stash pop stash@{1}7)git stash drop stash@{$num} :丢弃stash@{$num}存储,从列表中删除这个存储

(8)git stash clear :删除所有缓存的stash

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

布尼卡

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值