文章目录

  • ​​git pull = git fetch + git merge​​
  • ​​git commit -a = git add + git commit​​
  • ​​回退到某版本​​
  • ​​问题及解决​​
  • ​​1.git push后出现错误​​
  • ​​2.用户名不正确无法访问​​
  • ​​3.git pull报错​​
  • ​​4.git不小心提交大文件导致无法提交问题​​
  • ​​5.git fatal: 拒绝合并无关的历史的错误解决​​


Git——基本命令指南及基本问题解决_版本号

git pull = git fetch + git merge

Git——基本命令指南及基本问题解决_git_02

git commit -a = git add + git commit

Git——基本命令指南及基本问题解决_git_03

回退到某版本

假设此时发现情况不对,之前的那次版本号为 5c04 的提交是正确的,刚才的版本回退操作全都是误操作,怎么办?再次执行一次版本回退吗?当然不需要啦,我们有 ​​git reflog​​​ 命令,它会记录本地仓库所有分支的每一次版本变化。实际上只要本地仓库不被删除,随你怎么折腾,都能回退到任何地方。​​reflog​​ 记录只存在于本地仓库中,本地仓库删除后,记录消失。执行此命令如下图所示:

Git——基本命令指南及基本问题解决_git_04


怎么回退到 5c04 那个版本呢?可以直接执行命令 ​​git reset --hard [版本号]​​​ ,如果记不清版本号,也可以根据上图第 3 行的信息,执行 ​​git reset --hard HEAD@{2}​​ 命令,其中 HEAD@{2} 就是上图第 3 行第 2 列所示,这个命令的意思是回到当前分支最近两次提交版本变化前:

Git——基本命令指南及基本问题解决_github_05


还想反悔,刚才还是改对了,怎么办?再执行一次即可,这次大括号里就是 1 了:

Git——基本命令指南及基本问题解决_错误解决_06

问题及解决

1.git push后出现错误

错误:​​![rejected] master -> master(non-fast-forward) error:failed to push some refs to 'XXX'​如图所示:

Git——基本命令指南及基本问题解决_git_07


操作流程:

本地创建了一个project

并在Gitee上创建了一个仓库,想要将本地的仓库链接到远程仓库

我用的是如下方法:

git init    //初始化本地仓库
git remote add origin XXX(仓库地址)     //添加远程仓库地址

如果你在这之后就执行:

git add .          //添加全部文件
git commit -m "备注提交的内容"            //提交文件
git push origin master

那么就会出现这个问题(被拒绝),所以在remote add后不要着急​​git add​​​,一定要​​git pull origin master​​,出现这个原因是因为:你在码云创建的仓库有ReadMe文件,而本地没有,造成本地和远程的不同步。

解决方法

  • 方法一:

本地没有ReadMe文件,那么就在本地生成一个:

git pull --rebase origin master     本地生成ReadMe文件
git push origin master
  • 方法二:
    那强制上传覆盖远程文件:
git push -f origin master

2.用户名不正确无法访问

如图所示:

Git——基本命令指南及基本问题解决_github_08


解决方法:

​​Git-remote Incorrect username or password ( access token )​​

3.git pull报错

Git——基本命令指南及基本问题解决_git_09


解决方法:

  • ​​Git冲突:commit your changes or stash them before you can merge(在合并之前提交或保存更改)​​

4.git不小心提交大文件导致无法提交问题

​​解决git不小心提交大文件导致无法提交问题​​

5.git fatal: 拒绝合并无关的历史的错误解决

​​git fatal: 拒绝合并无关的历史的错误解决​​