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

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

関連記事

Evernote

Evernoteに自動引き落しさせない方法

Evernoteに自動引き落しさせない方法について説明します。

Linux

scp の代わりとしての rsync コマンドとそのオプション

1. はじめに scp コマンドというのは、ssh コマンドを内部で使って、ローカルホストとリモートホスト間でファイルをコピーするためのコマンドです。ssh コマンドは SSH という暗号化された安全 …

Anki

Anki のデッキ(単語帳)は、基本的に階層構造にはしていません

Anki のデッキ(単語帳)は、基本的に階層構造にはしないという方針について説明します。

Chrome

Chrome のデベロッパーツールでは、リダイレクト直前のレスポンスボディが見られない

目次1. はじめに2. Chrome のデベロッパーツール3. Chrome のデベロッパーツールのバグ?4. Firefox の開発ツールなら大丈夫5. おわりに6. 参考 1. はじめに Web …

WSL

WSL 2 で Docker を使うパターン

目次1. はじめに1-1. Docker についての基礎知識1-2. 前提2. WSL 2 ディストロ(Ubuntu) + パッケージのDocker を利用するパターン3. WSL 2 ディストロ(U …