Reparieren der vorherigen lokalen Übertragung
Verwenden Sie git-gui (oder ähnliches), um eine git commit --amend
. Über die grafische Benutzeroberfläche können Sie einzelne Dateien aus der Übergabe hinzufügen oder entfernen. Sie können auch die Commit-Nachricht ändern.
Rückgängigmachen der vorherigen lokalen Übertragung
Setzen Sie Ihre Verzweigung einfach auf den vorherigen Standort zurück (z. B. mit gitk
o git rebase
). Wenden Sie dann Ihre Änderungen aus einer gespeicherten Kopie erneut an. Nach der Garbage Collection in Ihrem lokalen Repository wird es so sein, als ob die unerwünschte Übertragung nie stattgefunden hätte. Um all dies mit einem einzigen Befehl zu erledigen, verwenden Sie git reset HEAD~1
.
Ein Wort der Warnung : Unvorsichtige Verwendung von git reset
ist ein guter Weg, um Ihre Arbeitskopie in einen verwirrenden Zustand zu versetzen. Ich empfehle Git-Neulingen, dies nach Möglichkeit zu vermeiden.
Rückgängig machen einer öffentlichen Übertragung
Durchführen einer umgekehrte Rosinenpickerei ( git-revert ), um die Änderungen rückgängig zu machen.
Wenn Sie noch keine anderen Änderungen auf Ihren Zweig gezogen haben, können Sie dies einfach tun...
git revert --no-edit HEAD
Pushen Sie dann Ihren aktualisierten Zweig in das gemeinsame Repository.
Der Commit-Verlauf zeigt beide Commits getrennt an .
Fortgeschrittene: Berichtigung der privat Zweig im öffentlichen Repository
Dies kann gefährlich sein - stellen Sie sicher, dass Sie eine lokale Kopie der Verzweigung haben, die Sie zurückschieben können.
Beachten Sie auch, dass Sie dies nicht tun sollten, wenn jemand anderes an dem Zweig arbeitet.
git push --delete (branch_name) ## remove public version of branch
Bereinigen Sie Ihren Zweig lokal und schieben Sie ihn dann neu...
git push origin (branch_name)
Im Normalfall brauchen Sie sich nicht darum zu kümmern, dass die Commit-Historie Ihres privaten Zweigs makellos ist. Schieben Sie einfach einen Folge-Commit (siehe 'Wie man einen öffentlichen Commit rückgängig macht' weiter oben) und machen Sie später einen squash-merge um die Geschichte zu verbergen.
2 Stimmen
Siehe diese Anleitung für das Rückgängigmachen von Git Commits auf Local, Public und Git Branch Wie man Git Commits wie ein Profi rückgängig macht
703 Stimmen
Weißt du, was Git braucht?
git undo
, das war's. Dann verschwindet der Ruf von Git, mit Fehlern von uns Normalsterblichen umzugehen. Implementieren Sie, indem Sie den aktuellen Zustand auf einen Git-Stack schieben, bevor Sie einegit
Befehl. Es würde die Leistung beeinträchtigen, daher wäre es am besten, ein Konfigurations-Flag hinzuzufügen, das angibt, ob es aktiviert werden soll.58 Stimmen
@YiminRong Das kann man mit Git's
alias
Funktion: git-scm.com/book/de/v2/Git-Basics-Git-Aliases137 Stimmen
Für VsCode-Benutzer, geben Sie einfach ctrl +shift +G ein und klicken Sie dann auf drei Punkte, d.h., mehr Optionen und klicken Sie dann auf Undo Last Commit
30 Stimmen
@YiminRong Undo was genau? Es gibt Dutzende von sehr unterschiedlichen funktionalen Fällen, in denen "Rückgängigmachen" etwas bedeutet vollständig anders. Ich würde wetten, dass die Hinzufügung eines neuen "Zauberstabs" nur noch mehr Verwirrung stiften würde.
52 Stimmen
@YiminRong Ich kaufe es nicht. Die Leute würden immer noch herumfummeln und Dinge rückgängig machen, die nicht rückgängig gemacht werden sollen. Aber was noch wichtiger ist,
git reflog
kommt dem, was du beschreibst, schon sehr nahe, gibt dem Benutzer aber mehr Kontrolle darüber, was (un)getan werden soll. Aber bitte, nein, "Rückgängig" funktioniert nicht überall gleich, und die Leute würden erwarten viele verschiedene Dinge, die das Feature erreichen soll. Letzte Übertragung rückgängig machen? Letzte Aktion rückgängig machen? Wenn die letzte Aktion ein Push war, wie genau rückgängig machen, (zurücksetzen und pushen) oder (rückgängig machen und pushen)?10 Stimmen
Um etwas Einfaches in Git zu tun, machen Sie entweder Impossibly Hard Task A oder Impossibly Hard Task B. Dann vermasseln Sie es ein wenig und versuchen, es durch Impossibly Hard Task C oder Impossibly Hard Task D rückgängig zu machen.
4 Stimmen
Git ist ein Framework, das die Versionierung vieler Dateien und die Zusammenarbeit ermöglicht. Es erfordert absolute Kontrolle darüber, was Sie tun, um diese Ziele zu erreichen. Es ist großartig genau weil es versucht, alle unnötige "Magie" wegzulassen. Etwas wie
git undo
ist im Allgemeinen eine schlechte Idee, aber es ist lächerlich einfach zu implementieren, wenn man es wirklich will. Aber seien Sie sich bewusst, dass Sie dann dafür verantwortlich sind. Ich finde es wirklich erstaunlich, wie schnell die Leute die Kontrolle aufgeben, um nichts lernen zu müssen. Git ist einfach Sie müssen nur die Konzepte lernen.3 Stimmen
"Dinge rückgängig machen, die nicht rückgängig gemacht werden sollen" - Diese Dinge wären alle Dinge. Wie kann ich meinen Quellcode wirklich etwas anvertrauen, das mich (oder andere) die Geschichte ändern lässt.
8 Stimmen
Argumentation gegen eine
undo
Befehl ist künstliche Schwerfälligkeit. Ja, Sie können dies mit einer Kombination ausreflog
,reset
etcheckout
. Das Problem ist, dass dies für jeden, der es nicht routinemäßig tut, eine völlig unnatürliche Willensbekundung ist. Mercurial hatrollback
und es hat nichts kaputt gemacht. Git sollte auch etwas haben.4 Stimmen
Sie können Folgendes installieren git-extras die eine Reihe von Git-Hilfsfunktionen sind - enthält die
git undo
Befehl, um die letzte Übertragung rückgängig zu machen. Ich benutze ihn ständig, wenn ich gerade etwas übertragen habe (und noch nicht gepusht habe) und eine nicht übertragene Datei hinzufügen oder den Commit-Kommentar ändern muss.0 Stimmen
@ashad - Ihr Vorschlag war für mich genau richtig! Danke!!
2 Stimmen
In Ihrem Fall können Sie einfach den Git-Reset durchführen (wenn Sie nicht in den Zweig gepusht haben). Wenn Sie bereits in den Zweig gepusht haben, führen Sie git reset --hard HEAD^1 aus.
0 Stimmen
Jedes Mal, wenn ich diesen Beitrag brauche, komme ich hierher, löse mein Problem und sage, was für ein schöner Beitrag :) danke euch allen.