git总结一、工作中常用基础命令
首先来了解两个概念:

$ git status
On branch master
Changes not staged for commit:
(use "git add <file>..." to update what will be committed)
(use "git checkout -- <file>..." to discard changes in working directory) modified: readme.txt Untracked files:
(use "git add <file>..." to include in what will be committed) LICENSE no changes added to commit (use "git add" and/or "git commit -a")
Git非常清楚地告诉我们,readme.txt被修改了,而LICENSE还从来没有被添加过,所以它的状态是Untracked。
2、
commit qaws1a4b1e251f07e4e8658fd2b1d6d0918ca44f (HEAD -> test_qy, origin/test_all, test_all)
Author: qy <quyang@123.com.cn>
Date: Thu Apr 25 13:49:10 2019 +0800 member page change commit qwsedeed7b208331ead8cc469fd568f0d4c2da05
Author: qy <quyang@123.com.cn>
Date: Thu Apr 25 11:44:50 2019 +0800 member strategy page style change commit 417fce1c1b1171f5ed9f5a5a6cb31e44ec41da77
Author: zhangsan <zhangsan@123.com.cn>
Date: Thu Apr 25 11:26:49 2019 +0800 modify some file commit 76ytd819f40a633d4ec3fc8f9d7662c6f234c0fb
Merge: eb784ae 000efaf
Author: lisi <lisi@123.com>
Date: Thu Apr 25 11:24:13 2019 +0800 update them commit tru24ae4162639ff01346cc12c1d578bddb5a33e
Author: lisi <lisi@123.com>
Date: Thu Apr 25 11:23:00 2019 +0800 update continue
fabe1a4 (HEAD -> test_qy, origin/test_all, test_all) HEAD@{0}: checkout: moving from test_local to test_qy
ae3c43b (origin/test_local, test_local) HEAD@{1}: cherry-pick: member page change
01311f0 HEAD@{2}: checkout: moving from test_all to test_local
fabe1a4 (HEAD -> test_qy, origin/test_all, test_all) HEAD@{3}: merge test_qy: Fast-forward
3f625ee HEAD@{4}: checkout: moving from test_qy to test_all
fabe1a4 (HEAD -> test_qy, origin/test_all, test_all) HEAD@{5}: checkout: moving from test_all_0001 to dbg_qy_0001
3f625ee HEAD@{6}: checkout: moving from dbg_qy_0001 to dbg_all_0001
fabe1a4 (HEAD -> test_qy, origin/test_all, test_all) HEAD@{7}: commit: member page change
3f625ee HEAD@{8}: checkout: moving from test_local to test_qy
01311f0 HEAD@{9}: cherry-pick: member strategy page style change
3a60b15 HEAD@{10}: pull: Fast-forward
84eee19 HEAD@{11}: checkout: moving from test_all to test_local
三、回退系列命令:
1、丢弃工作区的修改(此时还没有执行git add .)
git checkout -- "文件路径" 删除指定文件的修改,执行后工作区是干净的
2、丢弃暂存区的修改 (此时已经执行了git add .但是还没有执行git commit -m "")
要用的是git reset命令,步骤如下:
git log 查看commit历史信息,拿到最新一次提交的commit-id
git reset --hard/--soft/--mixed "xxx"(这里指拿到的commit-id)
git reset命令有三个可选的参数:
git reset --hard af4d64d4d5d51709a4a0af7db01e5f2a392f9a19
此命令执行后,工作区中的所有未提交的修改都会丢失,无论是否是你想要保留的部分
-- hard这个命令是很危险的,它是git里面少数几个会丢失信息的命令,虽然也可以通过git reflog来挽救,但最好还是不要使用此参数
git reset --soft af4d64d4d5d51709a4a0af7db01e5f2a392f9a19
此命令执行后,查看文件的状态并没有做任何改变,只是代码所作用的效果不显示了
git reset af4d64d4d5d51709a4a0af7db01e5f2a392f9a19 //默认参数为mixed
Unstaged changes after reset:
M index.html
此命令执行后,将暂存区的修改撤回到了工作区,即git add .之前的状态
git status //查看文件状态,修改已经被撤回到暂存区
On branch dbg_qy_0001
Changes not staged for commit:
(use "git add <file>..." to update what will be committed)
(use "git checkout -- <file>..." to discard changes in working directory)
modified: index.html
no changes added to commit (use "git add" and/or "git commit -a")
3、将提交到分支的修改撤回到工作区(即已经执行了git commit,但还没有git push)
git log //拿到想要撤销的修改前一次的提交id
git reset af4d64d4d5d51709a4a0af7db01e5f2a392f9a19
git status //查看状态看到提交到分支上的修改以已经撤回到工作区
On branch test_qy
Changes not staged for commit:
(use "git add <file>..." to update what will be committed)
(use "git checkout -- <file>..." to discard changes in working directory)
modified: src/index.vue
no changes added to commit (use "git add" and/or "git commit -a")
4、将push到远程的个人分支的修改撤回(已经执行了git push但是还未merge到公共的repository)
这种情况同样也可以使用git reset命令来回退,但是当你回退到某一个版本再次push的时候,由于本地的版本落后于远程的版本,此时需要使用git push -f强制推送。
注意这种情况是只有你一个人使用的远程分支
5、要回退的代码已被merge(合入)到公共的repository
git log //查看提交历史信息,拿到要撤回的那次提交的commit-id
git revert "xxx"(commit-id)
若产生冲突,手动解决冲突,然后提交;
git revert 与 git reset的区别:
git reset执行后,要回退的那次提交之后的所有提交都被撤回到工作区,如果其他提交是团队其他开发人员做的,那么就会影响到其他人的代码,这样做是不合理的。
git revert 撤销 某次操作,此次操作之前和之后的commit和history都会保留,并且把这次撤销
作为一次最新的提交
* git revert HEAD 撤销前一次 commit
* git revert HEAD^ 撤销前前一次 commit
* git revert commit (比如:fa042ce57ebbe5bb9c8db709f719cec2c58ee7ff)撤销指定的版本,撤销也会作为一次提交进行保存。
git revert是提交一个新的版本,将需要revert的版本的内容再反向修改回去,
四、删除命令:
rm "文件"
rm test.txt
git总结一、工作中常用基础命令的更多相关文章
- 工作中常用Linux命令--服务器运维
工作中常用Linux命令--服务器运维 lsof查看端口使用情况 lsof -i:8080更多lsof命令使用说明:http://www.cnblogs.com/peida/archive/2013/ ...
- 工作中常用Lixu命令学习笔记
对于Linux,我是菜鸟,也是在工作中了才开始慢慢接触,用Linux的人都我都会觉得屌屌的,现在把工作中常用的一些Linux命令记录一下,供以后学习和参考. cd 这可能是我觉得Linux最简单的一个 ...
- 工作中常用Linux命令
建立软链接 ln -s 例:ln -s b a 解释:把文件夹a和文件夹b关联起来,访问文件夹a,实际访问的是问价夹b 删除软连接 rm -rf a 直接删掉a文件夹跟a和b的软连接. ...
- git 工作中常用命令(结合vscode学习git 命令)
作为一名前端开发,大家在工作中常常使用什么开发工具呢,我觉得我首选的是vscode,他配合git使用起来非常方便. 工作中常用三个命令: git终端常使用: git add . git commit ...
- 【基础】工作中常用的linux命令,经常会被面试官问到
前言 面试经常会问到一些Linux操作命令,下面就工作中常用的和面试问的频率较高的命令做详细描述. 常用命令 修改密码:passwd 用户名 切换用户名:su 用户名 查看当前路径:pwd 调整路径: ...
- git工作中常用操作总结
这篇文章主要记录下工作中常用的git操作.主要是对之前文章记录的问题做个总结,这个其实在idea中操作更加简单 别名配置 在敲git 命令时,其实可以使用别名,比如 commit可以配置为ci 下面是 ...
- 工作中常用的Linux命令:mkdir命令
本文链接:http://www.cnblogs.com/MartinChentf/p/6076075.html (转载请注明出处) 在Linux系统中,mkdir命令用来创建一个目录或一个级联目录. ...
- 工作中常用的Linux命令:crontab命令
本文链接:http://www.cnblogs.com/MartinChentf/p/6060252.html (转载请注明出处) crontab是一个用来设置.删除或显示供守护进程cron执行的定时 ...
- 工作中常用的Linux命令:ipcs/ipcrm命令
本文链接:http://www.cnblogs.com/MartinChentf/p/6057100.html (转载请注明出处) ipcs 1. 命令格式 ipcs [resource-option ...
随机推荐
- 微软开发者大会:VS 2019 Preview 发布;Windows UX 主要技术开源
美国当地时间12月4日,微软正式举行 Microsoft Connect(); 2018 开发者大会,本次大会的 slogan 是"Build the apps of tomorrow, t ...
- 权限管理系统之SpringBoot集成LayUI实现后台管理首页
万事开头难,昨天一直在构思用户权限管理系统怎么实现,实现哪些需求,采用什么技术等,也在网上百度了好多,计划使用SpringBoot + Mybatis + thymeleaf + LayUI + S ...
- [CSS] input样式定制
input样式 定制一个泥团input,想怎么捏就怎么捏 appearance: none 所有主流浏览器都不支持 appearance 属性. Firefox 支持替代的 -moz-appearan ...
- Springboot整合activemq
今天呢心血来潮,也有很多以前的学弟问到我关于消息队列的一些问题,有个刚入门,有的有问题都来问我,那么今天来说说如何快速入门mq. 一.首先说下什么是消息队列? 1.消息队列是在消息的传输过程中保存消息 ...
- 大华门禁SDK二次开发(二)-SignalR应用
经过与大华技术支持的沟通,门禁服务程序已经开发好了,可以正常接收门禁开关事件,可以发送开门命令.基于项目实时性要求,这里使用SignalR实现门禁状态.控制命令的实时传送. 几种场景需求 根据Sign ...
- Easyui datagrid combobox输入框下拉(取消)选值和编辑已选值处理
datagrid combobox输入框下拉(取消)选值和编辑已选值处理 by:授客 QQ:1033553122 测试环境 jquery-easyui-1.5.3 需求场景 如下,在datagri ...
- Android studio怎么使用自定义的framework而避免冲突报错和点不进去报红。
文件:xx\project_abc\video\build.gradle保证可以运行到自定义的framework而不报错,可能因为project和module名字相同所以导致下面的路径是绝对路径,其他 ...
- redis -hash(哈希.对象)
hash 用于储存对象,对象的结构为属性.值 值的类型string 增加.修改: 设置单个属性: hset 键 field 值 例如: 设置键 user 的属性name 为 python hset u ...
- php连接数据库,以及日期处理函数
php连接数据库,以及日期处理函数 $conn=mysql_connect("10.0.10.0:0000","root","123456" ...
- CTF杂项之BubbleBabble加密算法
这题很坑,刚开始我拿到就分析不出来了(/无奈),关键是不知道是什么加密算法,后来看题目描述的bubble,猜测是bubble 这种算法(听都没听说过...) 上图 这串编码 xinik-samak-l ...