質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Git

Gitはオープンソースの分散バージョン管理システム(DVCS)です。

GitHub

GitHubは、Gitバージョン管理システムを利用したソフトウェア開発向けの共有ウェブサービスです。GitHub商用プランおよびオープンソースプロジェクト向けの無料アカウントを提供しています。

Q&A

解決済

2回答

452閲覧

git reset --hard HEAD^で戻りすぎて、前のheadを取り消す方法の確認

sequelanonymous

総合スコア123

Git

Gitはオープンソースの分散バージョン管理システム(DVCS)です。

GitHub

GitHubは、Gitバージョン管理システムを利用したソフトウェア開発向けの共有ウェブサービスです。GitHub商用プランおよびオープンソースプロジェクト向けの無料アカウントを提供しています。

1グッド

1クリップ

投稿2018/09/07 12:01

git reset --hard HEAD^で戻りすぎてしまい、せっかく時間をかけた修正後のファイルが元に戻ってしまいました。

方法は以下だと思っています。
https://qiita.com/yaotti/items/e37c707938847aee671b

しかし、その前にgit add -Aをしていますが、普通にgit reset --hard HEAD@{1}
をして、前のコードに戻せるものだしょうか?すみません、git初心者で少し不安で質問させて頂きました。

marutto👍を押しています

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

git add したものについては、git stashを行うことで、一旦stashに退避できます。

そのあと、reflogとreset --hardを使ってブランチの状態を元に戻すとよいでしょう。

そのあと、git stash popでstashの状態を手元のコードに適用できます。

このときconflictする可能性がありますが、
conflictしても落ち着いて手元のコードをmergeしましょう。
mergeに失敗しても、conflictが起きた場合は、stash 側は残ったままなので、
もう一度git stash popで、適用を試みることができます。

投稿2018/09/07 12:20

takumiabe

総合スコア661

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

sequelanonymous

2018/09/07 16:01

ありがとうございます!できました!
guest

0

git reflog

でログがみれます

投稿2018/09/07 12:09

Nippun

総合スコア1147

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問