zoukankan      html  css  js  c++  java
  • 10 个很有用的高级 Git 命令(转)

    英文原文:10 Useful Advanced Git Commands

    迄今,我已经使用Git很长一段时间了,考虑分享一些不管你是团队开发还是个人项目,都受用的高级git命令。

    1. 输出最后一次提交的改变

    这个命令,我经常使用它 来发送其他没有使用git的人来检查或者集成所修改的。它会输出最近提交的修改内容到一个zip文件中。

    git archive -o ../updated.zip HEAD $(git diff --name-only HEAD^)

    2. 输出两个提交间的改变

    类似的,如果你需要输出某两个提交间的改变时,你可以使用这个。

     git archive -o ../latest.zip NEW_COMMIT_ID_HERE $(git diff --name-only OLD_COMMIT_ID_HERE NEW_COMMIT_ID_HERE)

     3. 克隆 指定的远程分支

    如果你渴望只克隆远程仓库的一个指定分支,而不是整个仓库分支,这对你帮助很大。

    git init

    git remote add -t BRANCH_NAME_HERE -f origin REMOTE_REPO_URL_PATH_HERE

    git checkout BRANCH_NAME_HERE

    4. 应用 从不相关的本地仓库来的补丁

    如果你需要其它一些不相关的本地仓库作为你现在仓库的补丁,这里就是通往那里的捷径。

     git --git-dir=PATH_TO_OTHER_REPOSITORY_HERE/.git format-patch -k -1 --stdout COMMIT_HASH_ID_HERE| git am -3 -k

    5. 检测 你的分支的改变是否为其它分支的一部分

    cherry命令让我们检测你的分支的改变是否出现在其它一些分支中。它通过+或者-符号来显示从当前分支与所给的分支之间的改变:是否合并了(merged)。.+ 指示没有出现在所给分支中,反之,- 就表示出现在了所给的分支中了。这里就是如何去检测:

     git cherry -v OTHER_BRANCH_NAME_HERE

     #例如: 检测master分支

     git cherry -v master

    6.开始一个无历史的新分支

    有时,你需要开始一个新分支,但是又不想把很长很长的历史记录带进来,例如,你想在公众区域(开源)放置你的代码,但是又不想别人知道它的历史记录。

    git checkout --orphan NEW_BRANCH_NAME_HERE

    7. 无切换分支的从其它分支Checkout文件

    不想切换分支,但是又想从其它分支中获得你需要的文件:

    git checkout BRANCH_NAME_HERE -- PATH_TO_FILE_IN_BRANCH_HERE

    10.使用rebase推送而非merge

    如果您正在团队中工作并且整个团队都在同一条branch上面工作,那么您就得经常地进行fetch/merge或者pull。Git中,分支的合并以所 提交的merge来记录,以此表明一条feature分支何时与主分支合并。但是在多团队成员共同工作于一条branch的情形中,常规的merge会导 致log中出现多条消息,从而产生混淆。因此,您可以在pull的时候使用rebase,以此来减少无用的merge消息,从而保持历史记录的清晰。

    git pull --rebase

    您也可以将某条branch配置为总是使用rebase推送:

    git config branch.BRANCH_NAME_HERE.rebase true

     转载自:http://www.oschina.net/translate/10-useful-advanced-git-commands?from=20130826

  • 相关阅读:
    idea 插件之 SequenceDiagram
    idea 中添加mybatis的mapper文件模板
    springBoot 中 logback配置文件详解
    Mysql show processlist、show profiles 排查问题
    input 输入框效验
    Java基础之comparator和comparable的区别以及使用
    mysql sql使用记录
    mysql 优化之索引的使用
    IDEA 中常用快捷键的使用
    form表单中method的get和post区别
  • 原文地址:https://www.cnblogs.com/JoannaQ/p/3284110.html
Copyright © 2011-2022 走看看