git 命令大全

xiaoxiao2021-02-28  27

关注公众号QXF069

克隆版本:git clone  path路径 [<directory>]  若默认则是文件的名字。

查看远程版本库的地址   git remote -v | --verbose

将本地版本库和远程URL关联起来 git remote add [-t branch] <name(origin)> <Repository URL> # 如果指定-t branch,只会把branch分支同步下来,否则所有分支都会同步到本地。可以指定多个-t参数,将这些特定分支同步下来

取消本地版本库和远程URL的关联  git remote rm <name(origin)>

删除那些远程版本库中已经删除,但本地还存在的分支  git remote prune [--dry-run] <name(origin)># 使用--dry-run参数,可以列出那些分支将被删除,但不会执行删除操作

列出本地分支(当前分支前面有个#)git branch [-v] [-r | --remotes | -a | --all] [-v | -vv]

# -v 查看冗余信息(最近一次提交的commitId以及注释)

# -vv 查看冗余信息,还包括对应的up-stream

# -r 或 --remtotes 查看远程分支(不加-r 或 -a的话只查看本地分支)

# -a 或 --all 查看所有分支(本地+远程)

删除本地分支(delete) git branch -d | -D <branchName>  # -d 如果代码没有合并,不让删除

# -D 不管有没有合并强制删除分支

重命名分支名字(move/rename) git branch -m | -M <oldBranchName> <newBranchName># -m 如果有重名分支,不让重命名 # -M 如果有重名分支,强制重命名oldBranchName为newBranchName,并替换原来的newBranchName

根据当前分支创建新分支,但不切换到新分支上 git branch <newBranchName> [<startPoint>]# 如果需要创建新分支并切换到新分支,可以用:git checkout -b <newBranchName>  # <startPoint>可以是一个分支名称、commitId、tag标签。如果没有指定<startPoint>,创建的新分支将指向当前分支的HEAD,否则会指向<startPoint>对应的commit

关联本地分支和远程分支  git branch --track develop origin/develop # 关联以后,执行pull或push命名就可以不用再指定origin了

获取远程最新代码 git fetch <name(origin)> <branchName>[:<otherBranchName>]

合并(最好用工具合并 git merge --no-ff <branchName>  # --no-ff 创建一个merge的commit

如果merge时不能进行fast-forward,则不进行merge  git merge --ff-only <branchName>

获取并合并到当前本地分支(如果有冲突,同样可以用mergetool解决冲突) git pull 等价于 git pull origin

获取远端的<branchName>分支,并合并到当前分支 git pull --no-ff origin <branchName>

推入远程库 git push origin <branchName>

删除远程分支 git delete origin :<branchName>

提交git commit [-a | --all] -m "<commitMessage>" # 如果指定-a参数,那些修改或者删除的文件,虽然没有被add,但是也会被提交(新建的文件不会);如果不指定-a参数,只有add过的文件才会被提交 # -m 提交注释

 增补提交 git commit -C head -a --amend # 前提是想要进行增补提交的那个commit还没有被push到远端

切换到分支 git checkout <branchName>

新建并检出分支 git checkout -b <newBranchName> [<startPoint>] # 如果没指定<startPoint>,则从当前分支的HEAD检出

将工作区的指定文件或目录回退版本 git checkout <startPoint> <fileName/directoryName># <startPoint> 如果是HEAD,则相当于撤销当前文件的修改,如果是一个commitId,则回退到特定的版本

反转提交(撤销提交)git revert head

复位到之前的版本git reset --hard head^^

# 如果不加显示添加reset模式,默认是mixed模式

# reset模式  HEAD位置  暂存区  工作目录

# soft       修改      不修改  不修改

# mixed      修改      修改    不修改

# hard       修改      修改    修改 # head^^ 表示回退到从head开始数的第三个版本(也就是回退了两个版本)

查看暂存栈 git stash list

删除暂存git statsh drop [<stash>]

查看当前文件的变更状态git status

使用GUI来查看历史记录gitk

使用命令行来查看历史记录git log [-n <num> | -<num>] [-p] [--pretty=format:"<format>" | --pretty=(oneline|short|full)] [--graph] [<fileName>] [--grep=<grepString>] [--after=<date>] [--before=<date>] [--author=<author>] [--committer=<committer>]

查看文件状态 git ls-files [-t] [-c] [-d] [-m] [-o] [-u] [<fileName/directoryName>]

创建标签git tag 1.0

为某次提交创建标签

git tag 1.0 1b2e1d63ff

显示标签列表

git tag 

切换到标签(只能查看不能提交)

git checkout 1.0

找回被删除的提交 git fsck --lost-found # 可以用 git show <commitId> 的方式查看是否是要找的那个提交

# 如果是的话,可以用git rebase或git merge来恢复

关注公众号:

                 

               

转载请注明原文地址: https://www.6miu.com/read-2626001.html

最新回复(0)