matytan

git rebase

  • git rebase是一个非常有用的命令,但知道和用的人非常少,今天介绍一下其作用

git rebase -i

  • 作用:常用来合并多个相同目的的提交。
  • 交互式有下面几个命令,常用命令
    | 命令 | 作用 |
    | ---- | --------------------------------------- |
    | p | 使用 commit |
    | r | 使用 commit,并修改提交信息 |
    | e | 编辑 commit,用于需要修改 commit 文件时使用,进入 edit 之后,然后修改文件或添加文件 |
    | s | 使用最多的命令,用来合并上一个提交 |
    | | |
# Commands:
# p, pick <commit> = use commit
# r, reword <commit> = use commit, but edit the commit message
# e, edit <commit> = use commit, but stop for amending
# s, squash <commit> = use commit, but meld into previous commit

命令行操作

#### lazygit 操作 - 对应 lazygit 在提交信息栏,按 x 可以查看对应命令 ![]()

git rebase branch

  • 模拟场景

    • dev 开发完合并到了 master
    • 然后 dev2 开发完再去合并 master,我们可以看到 commit 2c8284ac出现分支,并且显示 Merge branch ‘dev2’
    • 此时我们想去掉这个分支
  • 使用git rebase dev2 或者在 lazygit 光标放在 dev2 上面按 r (不清楚命令可以通过 x 查看)

  • 最后效果就是一个分支,非常优雅

git pull --rebase

  • 当我们从远程拉代码的时候如果使用:git pull --rebase,则会以rebase的方式进行更新,而不是默认的merge。
  • 有时远程 rebase 过,那么拉的时候也需要 rebase

相关文章:

  • 2021-07-24
  • 2022-12-23
  • 2021-11-21
  • 2021-11-27
猜你喜欢
  • 2021-12-08
  • 2021-10-20
  • 2021-11-16
  • 2022-01-12
  • 2022-12-23
  • 2021-10-29
相关资源
相似解决方案