1、分支:git branch
新建本地分支:git branch <branchname>
查看本地分支:git branch
删除本地分支:git branch –d <branchname>
查看远程分支:git branch –r
查看远程本地分支:git branch -a
2、添加文件暂存区:git add
添加单个文件:git add <file>
添加目录:git add <path>
说明:本地工作区下有untracked文件和trached文件, 使用git add <path>方式添加时只会将目录下trached文件将会被添加到暂存区。untracked文件需要使用git add <file>添加到暂存区。
3、删除文件:git rm
4、提交:git commit
提交并加上log:git commit –m “log”
追加提交到最后一次(不生成新的log):git commit --amend
5、git checkout
从版本库同步到本地工作区:git checkout <file> / git checkout .
说明:处于暂存区的文件将不会被同步。
切换本地分支:git checkout <branchname>
创建分支并切换:git checkout –b <branchname>
同步远程分支代码并切换到本地分支:git checkout –b <localBranch> <remoteBranch>
6、git reset
git reset --hard HEAD^ 恢复到最近一次提交过的状态(相当于清空本地工作区修改和暂存区修改和本地仓提交记录):git reset --hard HEAD^^
git reset --mixed HEAD~1 默认选项;清除本地仓提交记录,并将修改还原到本地;
git reset --soft <commit-id> 恢复到指定的提交记录,将修改还原到缓存区;
7、git revert
恢复某次提交的状态:git revert <commit-id>
说明:恢复动作本身也创建一次提交对象
恢复最后一次提交的状态:git revert HEAD (当本地工作区有修改或者暂存区有修改时将失败)。
8、查看修改状态:git status
9、显示提交内容:git show
git show <$id> :这里的$id是commit提交生成的id,不是Change-Id。如下:
git show HEAD git show HEAD^^
git show HEAD~2 git show HEAD^2
10、查看文件差异:git diff
比较工作区和缓存区单文件差异:git diff <file>
比较缓存区和版本库单文件的差异:git diff –cached <file>
比较工作区和缓存区目录下文件差异:git diff <path>
比较缓存区和版本库目录下文件的差异:git diff –cached / git diff --staged
比较两次提交之前的差异:git diff <$id1> <$id2>
比较两个分支:git diff <branch1> <branch2>
仅仅比较统计信息:git diff –stat
11、查看提交记录:git log
git log –pretty=oneline 文件名
从gerrit恢复修改到本地git cherry-pick
12、git cherry-pick <commitid>
假设gerrt的修改连接是URL-A,使用git cherry-pick这种方式同步修改到本地之后,如果修改后使用git commit –amend方式提交,repo upload 后,修改记录仍然在URL-A上。