直前のコミットの取り消し方法Git

Git

直前のコミットの取り消し方法 [Git]

他人が触っているブランチと間違えてコミットしてしまった時など、直前のコミットを削除したい時があります。

git pushを取り消すには2つの方法があります。

  1. git revert コミットを打ち消す(履歴は残る)
  2. git reset コミットをなかったことにする(履歴は残らない)

ややこしいことにgit resetには3つの種類(オプション)があります。

    • reset --hard:全てをマルっと消す。
    • reset --mixed:commitとaddを取り消す。
    • reset --soft:commitのみ取り消す。

--hardは容赦無く消してしまうため現在のファイルの中身が変わって困る場合使えません。addしたものを忘れられると困る場合は--softを利用します。(おおよその場合--softで十分だと思います)

実行時は作業したいブランチを切り替えます(チェックアウト checkout)。

git revert

## 直前のコミットの内容を打ち消すためのコミット
$ git revert HEAD
## 直前のコミットがないか確認する
$ git log --oneline
## 打ち消したコミットのプッシュする
$ git push origin ブランチ名

revertは履歴を残すため、誤ったコミットとそれを打ち消すためのコミットの2つが残ります。

通常は圧倒的にrevertの方がいいですが、前述の通り純粋なオペミスなど不意に出来てしまった誤コミットは、revertすると不要な履歴が出来てしまうためresetしてしまったほうが良いと思います。

git reset

## 直前のコミットを取り消すが変更した内容は取り消さない
$ git reset --soft HEAD^
## 直前のコミットがないか確認する
$ git log --oneline
## 強制的にプッシュする(履歴を書き換える)
$ git push -f origin ブランチ名

git log --oneline

git log --oneline

を使うことで今いるブランチのコミットログを見る事ができます。

これでresetする前と後で直前のコミットが消えているか確認することができます。

コマンド実行後はLinuxのlessコマンドと同じためqで抜ける事が可能です。

今日の一杯 赤ワイン

2025/7/7

フェウド・アランチョ ネロ・ダーヴォラ レビュー|今日の一杯 赤ワイン

「フェウド・アランチョ ネロ・ダーヴォラ」は、味わい深く、コスパの良い、安定した品質の一本です。 トマト系の煮込み料理や、チーズをたっぷりのせたラザニアとも合い、もちろん、静かな夜にひとりでグラスを傾ける時間にもぴったり。 海外の専門家たちからも高評価を得ており、日常使いからしっかりした食事まで汎用的に活躍します。 味と風味 口に含むと、熟したダークベリーやラズベリーの果実味が広がりながら、後半にかけてほんのりドライハーブのような余韻が続きます。 酸味は控えめで、タンニンはしっかりしています。 飲みごたえ ...

続きを読む

エナジードリンク 今日の一杯

2025/6/30

ZONe ENERGY ABSOLUTE VICTORY 勝 レビュー|今日の一杯 エナジードリンク

ZONe ABSOLUTE VICTORYは2025年1月に発売されたエナジードリンクです。 受験勉強をイメージしたデザインの商品で、学問の神様として知られる菅原道真公を祀る太宰府天満宮に「HYPER ZONe 」を奉納し、受験生の合格を祈願しているそうです。 寒い冬に体を温めるように、成分にジンジャーシロップが配合されており、堅調に生姜の味がします。 カナダドライのジンジャーエールとはまた違う、比較的マイルドな飲みやすい生姜ジュースといった印象です。 ZONeの1本あたりのカフェイン量は75mgとコーヒ ...

続きを読む

  • この記事を書いた人

朝倉卍丸

シングルモルトスコッチなどのお土産を持ってきた人を助けるのが好きです。サービスの分割が重要ですが、まあ昔ながらの方法でやりたいこともありますよね。

よく読まれている記事

条件の0=0は全てが正であるを意味するSQL 1

SQLの条件に0=0のような記述を見かけます。 変わった書き方の条件ですが、これは「全てが正である」事を意味しており、結合条件の場合はCROSS JOINと同じです。 下記の例で言えば、結合するsub ...

DISTINCTを使わないで重複排除を考えるSQL 2

SQLのDISTINCTはEXISTSとかGROUP BYでなんとかする事もできます。 DISTINCTは暗黙的なソートがされますが、何のDBを使うにせよ過去のバージョンならともかく、最近のバージョン ...

RFC 5322に準拠させた正規表現言語別 3

RFC5322で定義されている正規表現を、各言語の正規表現に変化させた形になります。 完全な電子メール正規表現は存在しないので、結局のところ何かの公式基準に従っていたとしても、自分が携わるサービスのル ...

-Git