1. 先看一下git的命令:
查看本地分支 git branch ;
查看远程分支 git branch -r ;
切换分支 git checkout -b agrochemical origin/agrochemical;
查看所属分支 git branch -a;
回退命令: $ git reset --hard HEAD^;
回退到上个版本 $ git reset --hard HEAD~3;
回退到前3次提交之前,以此类推,;
回退到n次提交之前 $ git reset --hard commit_id;
退到/进到 指定commit的sha码 $ git checkout commit ID;
查看提交记录:$ git log;
强推到远程:$ git push origin HEAD --force
2.git之删除远程仓库文件,使用 git rm 命令即可,有两种选择:
一种是 git rm --cached "文件路径",不删除物理文件,仅将该文件从缓存中删除;一种是 git rm --f "文件路径",不仅将该文件从缓存中删除,还会将物理文件删除(不会回收到垃圾桶)。
假如你有文件不小心commit到了服务器那么你想要删除它,可以使用:git rm -- cached "路径+文件名" ;
git commit -m "delete file" ;
git push;git rm -r "路径+文件名" ;
git commit -m "delete file";
git push
3.接下来就是正事了,你在工作中一定用的到:
一、分支创建与切换1、创建新的分支并切换到该分支上进行提交首先我们先从最简单的来,下方演示了git分支的创建和切换的最基本的操作,具体步骤如下:
1》git branch <分支名>: 首先使用 git branch bugfix01,在当前分支也就是master分支上创建了一个名为bugfix01的新分支。
2》git checkout <分支名> : 然后使用 git checkout bugfix01 命令来切换到我们新创建的bugfix01的新分支上。
3》git commit : 最后使用 git commit 命令在新的分支上进行代码提交。
4、创建并切换分支
1》git checkout -b <分支名>: 首先使用 git checkout -b bugfix02 命令在当前所在分支bugfix01上创建一个新的分支并且切换到新创建的bugfix02上。
2》git commit : 然后就可以使用 git commit 在新的分支 bugfix02 上进行提交了。
二、分支的合并与删除以及冲突解决
1、分支的合并-merge首先使用 git checkout master命令切换到master分支上。
然后使用 git merge bugfix01 命令将 bugfix01 分支的修改合入到master分支上,在合入成功后会将合入后的新文件进行提交,此刻会有一个新的commit号,也就对应着下方的C9。
然后使用 git merge bugfix02,在将 bugfix02上的修改合入到master分支上,merge 对应的commit号为C10。最后还是可以在master分支上进行正常提交的。
2、分支的删除上面可以看到,虽然 bugfix01 和 bugfix02 的分支已经被合入到master分支上了,但是这两个分支还是存在的。
如果我们不需要这两个分支指针了,可以将两个分支指针进行删除:首先使用 git branch -d bugfix01对分支 bugfix01 进行删除。
然后使用 git branch -d bugfix02 对分支 bugfix02 进行删除。
操作上来看对分支的删除只是删除的指向该commit号的指针,并不会删除其相关的提交号, 在日志中仍然可以找到之前的commit记录,也仍然可以在该commit上创建新的分支。
如果你想删除远端的分支的话,那么得使用 $ git push origin --delete <分支名> 了。
# 克隆 git clone 仓库地址 git clone -b 分支名 仓库地址 # 查看分支 这里是看的本地的分支$ git branch* master# 接着是查看远程分支$ git branch -a* master remotes/origin/HEAD -> origin/master remotes/origin/hz remotes/origin/master remotes/origin/new-sc remotes/origin/static remotes/origin/static_jcy remotes/origin/static_xy remotes/origin/xtf remotes/origin/yx_dev【 方法一# git branch <分支名> : 首先使用 git branch jxb_dev,在当前分支也就是master分支上创建了一个名为jxb_dev的新分支。$ git branch jxb_dev# 查看分支 这里是看的本地的分支$ git branch jxb_dev* master# git checkout <分支名> : 然后使用 git checkout jxb_dev 命令来切换到我们新创建的jxb_dev的新分支上。$ git checkout jxb_dev# git commit : 最后使用 git commit 命令在新的分支上进行代码提交。$ git commit 分支名> 分支名>
# 如果要将合并的master主分支代码推送到远程
$ git push】【方法二# git checkout -b <分支名> : 首先使用 git checkout -b jxb_dev02 命令在当前所在分支jxb_dev上创建一个新的分支并且切换到新创建的jxb_dev02上。$ git checkout -b jxb_dev02# git commit : 然后就可以使用 git commit 在新的分支 jxb_dev02 上进行提交了。$ git commit】【分支的合并与删除以及冲突解决】# 分支的合并-merge首先使用 git checkout master命令切换到master分支上$ git checkout master# 然后使用 git merge jxb_dev 命令将 jxb_dev 分支的修改合入到master分支上,在合入成功后会将合入后的新文件进行提交,此刻会有一个新的commit号,也就对应着下方的C9。$ git merge jxb_dev# 然后使用 git merge jxb_dev02,在将 jxb_dev02上的修改合入到master分支上,merge 对应的commit号为C10。$ git merge jxb_dev02# 最后还是可以在master分支上进行正常提交的。$ git commit# 【删除本地分支】git branch -d jxb_dev对分支 jxb_dev 进行删除$ git branch -d jxb_dev$ git branch -d jxb_dev02# 【提交和删除远程分支】$ git push origin test:master // 提交本地test分支作为远程的master分支 //好像只写这一句,远程的github就会自动创建一个test分支$ git push origin test:test // 提交本地test分支作为远程的test分支# 如果想删除远程的分支呢?类似于上面,如果:左边的分支为空,那么将删除:右边的远程的分支。$ git push origin :test // 刚提交到远程的test将被删除,但是本地还会保存的,不用担心 分支名>
参考: