git merge,rebase,reset
老分不清怎么用git merge 与 rebase 区别.
撤回的时候使用git reset 又忘了具体参数.
git log
显示提交的详细信息
commit 2ec3438b5c53932e928ec4284c5121acb86f2abb (HEAD -> mdfs-ng, origin/mdfs-ng)
Author: #小辉辉 <xxxx.com>
Date: Tue Apr 17 17:30:22 2018 +0800
clear : del unused code
git log –pretty=oneline
只显示commit id和提交的描述信息
2ec3438b5c53932e928ec4284c5121acb86f2abb (HEAD -> mdfs-ng, origin/mdfs-ng) clear : del unused code
8a78c5779328d2e48826b9203a50d596d508392f update : clear code by sonar
git reflog
可以查看所有分支的所有操作记录.包括已经删除commit记录
2a84922 HEAD@{158}: checkout: moving from hui-comment to devel
0d0b108 (master, hui-comment) HEAD@{159}: checkout: moving from master to hui-comment
HEAD
HEAD | 意义 |
---|---|
HEAD | 提交的最新版本 |
HEAD^ | 上一个版本 |
HEAD^^ | 上上个版本 |
HEAD~100 | 往上100个版本 |
HEAD@{index} | 提交索引 |
git reset
git reset --hard HEAD@{2}
git commit –amend
修改已经提交的信息
git rebase
合并
- 合并1~3条提交
git rebase -i HEAD~3 pick dc44d6b 根据sonar修改FixedLenChunkFingerIndexDB pick 8a78c57 update : clear code by sonar pick 2ec3438 clear : del unused code #将pick改为squash或者s,之后保存并关闭文本编辑窗口即可 pick dc44d6b 根据sonar修改FixedLenChunkFingerIndexDB s 8a78c57 update : clear code by sonar s 2ec3438 clear : del unused code
- 指名要合并的版本之前的版本号
git rebase -i 0d0b108
- 遇到冲突需要使用
git add . git rebase --continue
- 取消
git rebase --abort
Merging vs. Rebasing
The first thing to understand about git rebase is that it solves the same problem as git merge.
The Merge Option
git checkout feature
git merge master
#Or, you can condense this to a one-liner:
git merge master feature
The Rebase Option
git checkout feature
git rebase master