Tools

【Git】直前のコミットをもとに戻す方法

投稿日:2019年6月24日 更新日:

1. はじめに

Git で間違えてコミットしてしまった場合に、取り消す方法です。

2. 直前のコミットをもとに戻す方法

以下のどちらかを使えばよいでしょう。

最新のコミットを捨てる(変更箇所は捨てない)

$ git reset --mixed HEAD^
  • 変更した部分はそのまま残ります(add されていない状態に戻ります)。
  • --mixed は省略可(デフォルトなので)

最新のコミットを捨てる(変更箇所完全削除)

$ git reset --hard HEAD^
  • 変更した部分は削除されます。

3. 簡単な解説

(1) HEAD^ は、最新の一つ前のコミットを表します。

(2) git reset コマンドには「モード」と呼ばれるオプションが3種類あり、細かい動作を指定することができます。

git reset コマンドのモード
オプション 説明
--soft
  • コミットは取り消され、変更点が add された状態に戻ります。
--mixed
  • コミットは取り消され、変更点が add されていない状態に戻ります。
  • これがデフォルトで、省略可能です。
--hard
  • コミットは取り消され、何も変更していなかった状態に戻ります。
  • 間違ってこのオプションを指定してしまったら、git reflog コマンドを使い、過去のコミットを探して目的のコミットに現在位置を移動させましょう。

スポンサードリンク

📂-Tools

執筆者:labo


comment

メールアドレスが公開されることはありません。 が付いている欄は必須項目です

関連記事

Anki

Anki: 学習の流れを図にしました

Ankiにおける学習の流れを図にしました。

Windows

Audacityを使って、音声ファイルの一部分を抽出する

Audacityを使って、音声ファイルの一部分を抽出し、別のファイルとして保存する手順について説明します。

Anki

Ankiのフィールドに表を記述する

Ankiのフィールドに表を記述する。

英辞郎

英辞郎 on the WEB はどこに行った?

最近、株式会社アルクのURL https://www.alc.co.jp/ は完全にコーポレートサイトになったようです。英辞郎 on the WEB は全く表示されなくなり、英単語を調べることはできま …

データベース管理ツール Adminer

目次1. Adminer とは?2. Adminer の特徴A. たった1つのPHPファイルで動作するB. MySQL の多くの機能に対応しているC. 対応データベースが多いD. ユーザーインターフェ …