【git提交】流程,恢复丢弃的 git stash 数据

本文详细介绍了Git工作流程,包括如何在分支sml和master间提交、合并代码,以及git stash的使用技巧如保存、查看、应用和冲突解决。特别关注了git stash的管理,如git stashsave、git stashlist、git stashapply等,并演示了冲突处理步骤和误删stash的恢复策略。
摘要由CSDN通过智能技术生成

1- git提交(分支合并)操作流程:

git 提交代码到自己的分支,并合并到主分支的完整流程
分支 sml , 主分支, master

分支msl上操作
git status
git add .
git commit -m ‘xxxxxx’
git pull origin master
git push

切换到主分支master上
git checkout master
git pull origin master
git merge sml
git push

在这里插入图片描述

2- git提交操作流程,一个分支

1. git stash 或 git stash save "描述"  同步前先暂存你修改的内容
2. git pull 同步服务器最新代码
3. git stash apply 弹出暂存的修改
4 git status 查看修改的文件 
5. git add [文件]  .表示所有文件,也可以单独指定要提交的文件名
6. git commit -m "描述"
7. git push [远程分支] [本地分支] 或者是 git push - u origin dev  推送到远程服务器

如果有冲突情况下:
1- git pull 提示失败
2- git add . 和 git commit -m '提交本地'     把本地的提交
3- git push 提示 有冲突,解决冲突
4- 解决完后,重新 git add . 和 git commit -m '提交远程解决冲突'
5- git push 提示成功

在这里插入图片描述

1)git stash save "save message"  : 执行存储时,添加备注,方便查找,只有git stash 也要可以的,但查找时不方便识别。
(2)git stash list  :查看stash了哪些存储
(3)git stash show :显示做了哪些改动,默认show第一个存储,如果要显示其他存贮,后面加stash@{$num},比如第二个 git stash show stash@{1}4)git stash show -p : 显示第一个存储的改动,如果想显示其他存存储,命令:git stash show  stash@{$num}  -p ,比如第二个:git stash show  stash@{1}  -p
(5)git stash apply :应用某个存储,但不会把存储从存储列表中删除,默认使用第一个存储,即stash@{0},如果要使用其他个,git stash apply stash@{$num} , 比如第二个:git stash apply stash@{1}6)git stash pop :命令恢复之前缓存的工作目录,将缓存堆栈中的对应stash删除,并将对应修改应用到当前的工作目录下,默认为第一个stash,即stash@{0},如果要应用并删除其他stash,命令:git stash pop stash@{$num} ,比如应用并删除第二个:git stash pop stash@{1}7)git stash drop stash@{$num} :丢弃stash@{$num}存储,从列表中删除这个存储
(8)git stash clear :删除所有缓存的stash

(9)git stash被误删恢复,恢复丢弃的 git stash 数据
场景:
通过stash保存,被使用git stash drop 丢起。
项目开发中,不想commit提交,但要切换到其他commit或者branch,临时处理紧急任务,使用 git stash 备份当前的工作内容。但因不当操作使用“git stash drop”,暂存被删除
方案1要求:知道被删除的ID
通过历史操作记录,查看自己drop的ID,通过“git show ID”,“git stash apply ID” 进行查看和恢复
git fsck --lost-found 或者git fsck --unreachable 找到各丢弃的标识ID,如下
在这里插入图片描述
可配合通过方案1进行查看、内容恢复。
缺点:commitID 数量大(几百上千个),而且不是根据顺序进行排列的,找起来麻烦,不太使用

复制dangling commit 的id(其他的dangling blob不用关心)
查看

git show 900d07a43b935220d4e6b7eb36fb4b18c5f7848f(你的id)

还原

git merge 900d07a43b935220d4e6b7eb36fb4b18c5f7848f(你的id)

方案2:要求:知道被删除的大致内容
查询被clear的相关历史

git log --graph --oneline --decorate $(git fsck --no-reflog | awk '/dangling commit/ {print $3}')

在这里插入图片描述

找到 被clear 的stash记录
根据自己保存名称,直接 git stash apply ID 进行恢复;不记得名字可通过git show 查看具体内容,筛选需要的ID

git stash apply d052411

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值