常用命令
对本地做远程关联:git remote add upstream xxxxxxx.git #和 xxxxxxx.git源项目建立关联
查看分支:git branch
创建分支:git branch <name>
切换分支:git checkout <name>或者git switch <name>
创建+切换分支:git checkout -b <name>或者git switch -c <name>
删除分支:git branch -d <name>
查看状态:git stauts
合并某分支到当前分支:git merge <name>
查看分支
$ git branch # 查看当前分支
$ git branch -v # 查看最后一次提交日志
$ git branch -a # 列出本地和远程的所有分支
$ git branch --merged # 列出已经并入当前分支的分支
$ git branch --no-merged # 列出未合并的分支
$ git log --graph --pretty=oneline # 可视化分支
创建分支
# 1:创建并切换到新分支
$ git checkout -b sample-branch
# 2:仅仅创建分支(创建之前先查看分支 $ git branch)
$ git branch sample-branch
# 3:切换到sample-branch分支
$ git checkout sample-branch
1=2+3
删除分支
# 1:删除已经合并过的分支
$ git checkout -b sample-branch
# 2:没有合并的分支只能强制删除
$ git branch -D sample-branch
回滚
回滚到某个版本
一般不建议trunk回滚,最好建立一个分支,比如
$ git checkout -b rollback_1226
$ git log #查看所有日志
$ git log --pretty=oneline #过滤日志只显示commitID
$ git reflog # 查看一下reset之前的那个ref叫什么,比如 HEAD@{2}
$ git reset --hard HEAD@{2}
其中 git reset --hard 表示彻底回退到某个版本,本地源代码也会变成该版本,而git reset --soft 只回退commit信息,不会恢复到index file一级。
git reset soft,hard,mixed之区别深解
其他的一些回滚指令
$ git reset HEAD^ #回退所有内容到上一个版本
$ git reset HEAD^ a.py #回退a.py这个文件的版本到上一个版本
$ git reset --soft HEAD~3 #向前回退3个版本
$ git reset --hard origin/master #将本地的状态回退到和远程的一样
$ git reset 057d #回退到某个版本
网友评论