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

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

関連記事

Windows

WSL (Windows Subsystem for Linux) の導入と設定

本ページでは、WSL (Windows Subsystem for Linux) の導入と設定についてポイントをまとめています。

Linux

ウェブサーバー(Linux) 上で特定のクライアントとの通信を記録してWindowsで内容を確認する

ウェブサーバー(Linux) 上で特定のクライアントとの通信を記録してWindowsで内容を確認する方法について説明します。

Anki

大学入学共通テストの英語音声問題をAnkiのデッキにする

大学入学共通テストの英語音声問題を Anki のデッキにしてみましたので、その手順を紹介します。

Vim

Vim: 行番号の表示

Vim の行番号表示機能について説明します。 目次1. 前提とする環境2. 行番号表示に関する設定項目number (もしくは nu)relativenumber (もしくは rnu)3. この設定項 …

Windows

Putty でスクリーン上のやりとりをログファイルに保存する方法

目次1. はじめに2. Putty でログをとる手順3. ログファイルが既に存在していた場合の挙動設定4. おわりに 1. はじめに PuTTY とは、Windows用のターミナルエミュレータです。 …