git config --global alias.st 'status' // git st git config --global alias.cm 'commit' // git cm -m 'msg' git config --global alias.unstage 'reset HEAD' // git unstage fimeName git config --global alias.last 'log -1' // git last // 查看历史提交,推荐 git config --global alias.lg "log --color --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit" // git lg
// !只能存储已经被track的文件 git stash
git stash pop
git rebase -i 要合并的两个分支的上一个分支号
squash 表示这个 commit 会被合并到前一个commit
git checkout --patch 要merge的分支 filePath
git cherry-pick 62ecb3
git reset --hard HEAD^ // 回退到上个版本 git reset --hard HEAD~n // 回退到n次提交以前 git reset --hard commit_id // 退到/进到指定commit版本
git checkout --track origin/branch_name git checkout -b localBranch origin/originBranch
git tag tagName git tag -a tagName -m 'tagMsg' // 将本地标签推到远程 git push origin --tags/tagName // 删除本地标签 git tag -d tagName // 删除远程标签 git push origin :refs/tags/标签名
git rm -r --cached . git add . git commit -m 'update .gitignore' 若是仍是不行的话 在先将想要取消追踪的文件移到项目目录外,并提交,而后提交后再将刚刚移出的文件再移入项目中便可
若是是对全部文件都取消跟踪的话,就是git
git rm -r --cached . //不删除本地文件 git rm -r --f . //删除本地文件
对某个文件取消跟踪code
git rm --cached readme1.txt //删除readme1.txt的跟踪,并保留在本地。 git rm --f readme1.txt //删除readme1.txt的跟踪,而且删除本地文件。
git clean -df