一、查看丟失記錄
git fsck --lost-found
找回丟失的satsh記錄,只有commit?才能夠被恢復。
也可以執(zhí)行git log命令找到commit id。
二、查看具體內容
git show commitId
三、找到commitId 進行git merge commitId 即可
四、git回滾文件場景總結
1、修改完還未git add:使用 git checkout 回滾
使用暫存區(qū)的文件覆蓋工作區(qū),所以執(zhí)行完?git add .
?之后,再執(zhí)行該命令是無效的。?git checkout .
?和?git add .
?是一對反義詞。
2、git add提交還未commit
使用?git add
?提交到暫存區(qū),還未?commit
?之前,使用?git reset
?和?git checkout
?回滾:
git reset # 先用 Head 指針覆蓋當前的暫存區(qū)內容
git checkout . # 再用暫存區(qū)內容覆蓋工作區(qū)內容
或者使用直接使用 head (在git中,用HEAD表示當前版本)覆蓋當前暫存區(qū)和工作區(qū)。
# 恢復當前版本,刪除工作區(qū)和緩存區(qū)的修改
git reset --hard
3、已經(jīng)git commit還未git push
使用 git reset 回滾:覆蓋本地倉庫、暫存區(qū)和工作區(qū)
git reset --hard <last_commit_id>
4、已經(jīng)git push
git reset --hard <commit_id>
強制提交當前版本號:git push origin <遠端分支名稱> --force
五、Git:git-reflog的用法
參考:Git:git-reflog的用法總結_IT老兵驛站的博客-CSDN博客_git reflog
git-reflog()是用來恢復本地錯誤操作很重要的一個命令,示例如下:
?比如我們想恢復到某個版本,如下:
3aba2df HEAD@{4}: commit: tor-92 [Story] 性能測試服務化,服務號觸發(fā)時支持locust壓測地址替換
執(zhí)行如下命令即可:
git reset --hard HEAD@{4}
參考:
git stash clear后,如何找回并恢復代碼
commit的內容 還原git_工作中必備的git技能(上)_weixin_39673037的博客-CSDN博客文章來源:http://www.zghlxwxcb.cn/news/detail-431628.html
【git撤銷操作】git reset詳解_Chx.zhang的博客-CSDN博客_git 撤銷reset文章來源地址http://www.zghlxwxcb.cn/news/detail-431628.html
到了這里,關于git恢復commit過的代碼的文章就介紹完了。如果您還想了解更多內容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關文章,希望大家以后多多支持TOY模板網(wǎng)!