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/staticremotes/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将被删除,但是本地还会保存的,不用担心