Git常用命令操作
- 创建本地分支、同步远程分支
- 合并分支、推送到远程分支
- 将其他分支的某一次提交合并到当前分支
- 回滚分支、将当前分支回滚到某一次提交
- 撤销本次修改、放弃本次提交
- 将本次修改暂存起开,顺利切换分支后 在任意分支将暂存取出
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