首页 > 其他分享 >常用 Git 命令行操作

常用 Git 命令行操作

时间:2022-12-31 11:22:06浏览次数:56  
标签:文件 常用 git BRANCH -- 命令行 Git 提交 分支

本文记录了一些常用 Git 命令行操作的具体使用方式

git clone

  • git clone REPOSITORY_URL
    拉取仓库,并使用仓库名作为本地文件名

  • git clone REPOSITORY_URL FOLDER
    拉取仓库,并使用 FOLDER 作为本地文件名

git fetch

  • git fetch origin
    更新所有远程分支

  • git fetch origin BRACH
    更新指定远程分支

git pull

  • git pull origin
    相当于 fetch + merge 对应的上游分支

  • git pull origin BRACH
    拉取指定分支到当前分支

  • git pull origin --rebase master
    让本地分支重新基于远端的 master 分支

git push

  • git push origin
    把分支推到远端对应的上游分支

  • git push origin BRANCH
    把分支推到远端对应的分支

  • git push --set-upstream origin BRANCH
    把分支推到远端对应的分支,并将其设为上游分支(一般第一次提交自己的开发分支需要用到)

  • git push -f origin
    把分支强推到远端对应的上游分支(会覆盖远端分支,需要慎用)

  • git push origin -d BRANCH
    删除远程分支

git branch

  • git branch
    列出本地所有分支

  • git branch -a
    列出本地和远程分支

  • git branch -m NEW_BRANCH
    更新当前分支名

  • git branch -d BRANCH
    删除已合并的分支

  • git branch -D BRANCH
    强制删除分支(即使未合并)

git checkout

  • git checkout BRANCH
    切到对应分支

  • git checkout -b NEW_BRANCH
    创建新分支

  • git checkout -b NEW_BRANCH BRANCH
    基于 BRANCH 创建新分支

  • git checkout SHA-1
    切换到某个提交,也可以用 HEAD~N(N 为 1, 2, 3…)切到上 N 个提交

  • git checkout SHA-1 /PATH/TO/FILE
    把文件还原到相应的提交版本

  • git checkout —-theirs /PATH/TO/FILE
    有冲突时使用对方的文件版本

  • git checkout --ours /PATH/TO/FILE
    有冲突时使用自己的文件版本

  • git checkout -
    切换到之前的分支,适合在两个分支频繁切换时使用

git add

  • git add .
    把所有增加/修改/删除的文件标识为要提交

  • git add /PATH/TO/FILE
    只把单一文件标识为要提交,当有其他不需要提交的文件被修改时可使用

git commit

  • git commit
    git add 标识的文件进行提交

  • git commit -a
    把修改/删除的文件进行提交(如果有新增的文件,需要使用 git add 添加)

  • git commit -am "MESSAGE"
    把修改/删除的文件进行提交并指定注释(适用于临时或简单注释内容)

  • git commit --amend
    更新上一次提交,可以加上 -a 或在之前运行 git add 追加更新文件

  • git commit --amend --reset-author
    默认的更新提交是不改变作者的,如果需要改变可以明确配置

git cherry-pick

  • git cherry-pick SHA-1
    把某个提交应用到当前分支

git status

  • git status
    查看目前状态

git diff

  • git diff
    当前所有修改到的,没被标识为要提交的文件的更新内容

  • git diff --cache
    当前所有修改到的,并被标识为要提交的文件的更新内容

  • git diff /PATH/TO/FILE
    指定文件的更新内容,同样可以用 --cache 区分

git log

  • git log
    详细显示所有记录

  • git log -n 10
    显示最近 10 条记录

  • git log --oneline
    简要显示所有记录

  • git log --oneline master ^BRANCH | wc -l
    可以计算 BRANCH 和 master 分支相差多少个提交

git stash

  • git stash
    暂存修改/删除,或已标识为要 commit 的新增的文件

  • git stash -u
    暂存修改/删除/新增的文件,即新增文件可以不用 git add

  • git stash pop
    把暂存的文件重新放出来

git revert

  • git revert SHA-1
    通过形成一个新提交取消某个提交

  • git revert SHA-1 -m 1
    如果是合并节点,需要指定要取消提交对应的父节点
    例如合并是把 BRANCH_2 合并到 BRANCH_1,那么要在 BRANCH_1 取消这次合并,就应该指定 m 为 1(大多数情况都是这样)

git reset

  • git reset
    取消对要 commit 的文件的标识(相当于 git add 的撤销)

  • git reset --hard
    取消修改/删除或已标识为要 commit 的新增的文件的更新

  • git reset SHA-1
    取消从 SHA-1 之后的所有提交,但是保留提交文件的更新
    如果只想取消上一次提交,SHA-1 可以设为 HEAD^

  • git reset --hard SHA-1
    取消从 SHA-1 之后的所有提交,而且不保留提交文件的更新

git rebase

  • git rebase BRANCH
    让当前分支重新基于 BRANCH

  • git rebase -i SHA-1
    更新 SHA-1 以后的提交,可以 pick/pedit/edrop/dsquash/s 相应提交
    如果第一个提交使用 p,后面的提交使用 s,可以把多个提交合并成一个提交

git merge

  • git merge BRANCH
    把 BRANCH 合并到当前分支,尽量不形成合并节点

  • git merge --no-ff BRANCH
    把 BRANCH 合并到当前分支,并确保形成合并节点

  • git merge --squash BRANCH
    把 BRANCH 和当前分支的变更作为标识为要提交的内容,需要运行 git commit 完成只有一个提交的合并

git update-index

  • git update-index --assume-unchanged /PATH/TO/FILE
    当某个文件被临时修改,但不想提交,也不适合放到 .gitignore,可以用此命令让 git 不将其识别为已修改
    如果这个文件是新增的,就不能用这个命令了,不过可以把文件路径加到 .git/info/exclude

  • git update-index --no-assume-unchanged /PATH/TO/FILE
    恢复以上文件的修改识别

标签:文件,常用,git,BRANCH,--,命令行,Git,提交,分支
From: https://www.cnblogs.com/chanvin/p/common-git-command-line-operation.html

相关文章

  • gitlab 集成的一些SAST安全扫描工具
    企业内部使用gitlab作为源代码管理的越来越多了,同时目前gitlab不少企业特性也开源的社区免费版了,以下是支持的SAST清单可以参考参考清单Language(packagemanagers)/f......
  • 开源项目 Spartacus 的 git 分支使用规范
    ​​开源项目Spartacus的git分支使用规范​​ Spartacus开源项目里存在如下的git分支:feature/GH-xxxx分支用于简单的功能和错误修复epic/epic-name分支用于......
  • R语言对git安卓包分类统计、聚类、复杂网络可视化分析
    我们曾经为一位客户进行了短暂的咨询工作,他正在构建一个主要基于安卓包分类的分析应用程序。数据源是安卓的项目,把同一类功能的安卓代码的头部,每一个文件都有import 包名......
  • Github Package npm 应用发布实践
    GithubPackagenpm应用发布实践文章目录​​GithubPackagenpm应用发布实践​​​​1.简介​​​​2.创建新库​​​​3.编写index.js​​​​4.npminit初始化​......
  • github-keydb 知识
    https://github.com/Snapchat/KeyDB KeyDBisnowapartofSnapInc!Checkouttheannouncement hereReleasev6.3.0 isherewithmajorimprovementsaswe......
  • nodejs常用命令
    npm管理配置设置下载源npmconfigsetreqistryhttps://registry.npm.taobao.org查看下载源npmconfiggetreqistry设置缓存目录npmconfigsetcache"D:\npm\n......
  • Gitea 1.18.0 | API、表单、PR、LaTeX、代码搜索、Email、包管理等18项重大更新如约而
    经过数月的开发,我们自豪地推出了正式版的Gitea1.18.0。新的系统整合了日积月累的535个PR,包含修复补丁以及功能更改,我们建议管理员升级系统前创建快照、备份数据,确保切换......
  • git hook- prepare-commit-msg
    1.不能提交到masterproductionmain这几个分支2.分支名只能以feature|hotfix|bugfix|release|dev|improvement这几个开头3.自动加分支名到提交的消息上4.变基的情况......
  • SpringBoot - HttpServletRequest 与 HttpServletResponse 常用方法
    HttpServletRequest常用方法-CSDNHttpServletResponse常用方法-CSDN......
  • IBM MQ实际工作常用知识点
    最近的工作内容有些变化,开始接触了IBMMQ大概一个月时间,这一个月来一些总结如下,欢迎大家来批评指正,一些常见问题和坑点我也会及时补充在之后的时间里。共勉。新年快乐!IBM......