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

メールアドレスが公開されることはありません。

関連記事

Vim

テキストファイルの空行を Vim を使って削除する

テキストファイルの空行を Vim を使って削除する方法を紹介します。

Vim

Emmet-vim の HTML5用スニペットを変更する

Vim エディタには、HTML & CSS の入力補助を行う mattn/emmet-vim というプラグインがあります。 これを使うと、例えば ul>li*5 と入力した直後に、Ctr …

Windows

Cmder (または ConEmu) を使う際にいつも変更している設定項目

Cmder (または ConEmu) を使う際に、私が変更している設定項目を紹介します。 Cmder は、Windows で使えるターミナルエミュレータ(コンソールエミュレータ)ソフトウェアです。Cm …

Evernote

Evernote のマージ機能

Evernote のマージ機能について説明します。

Linux

前回 ./configure を実行した時に指定したオプションを確認する

目次1. 前置き (configure, make, make install)2. config.status ファイル(1) 前回 configure を実行した時の引数を表示する(2) 前回 c …