Heim > Datenbank > MySQL-Tutorial > Wie kann ich die Fehlermeldung „Tabelle in gespeicherter Funktion/gespeichertem Trigger kann nicht aktualisiert werden' verhindern, wenn ich After-Update-Trigger verwende?

Wie kann ich die Fehlermeldung „Tabelle in gespeicherter Funktion/gespeichertem Trigger kann nicht aktualisiert werden' verhindern, wenn ich After-Update-Trigger verwende?

Linda Hamilton
Freigeben: 2024-12-26 22:28:14
Original
702 Leute haben es durchsucht

How Can I Prevent

Aktualisierungen nach derselben Tabellenaktualisierung auslösen

In Datenbanksystemen werden Trigger verwendet, um automatisch bestimmte Aktionen auszuführen, wenn bestimmte Ereignisse innerhalb einer Tabelle auftreten. Eine häufige Herausforderung entsteht, wenn versucht wird, dieselbe Tabelle innerhalb eines Triggers nach einer Aktualisierung dieser Tabelle zu aktualisieren.

Berücksichtigen Sie den folgenden Trigger:

CREATE TRIGGER upd_total_votes AFTER UPDATE ON products_score
FOR EACH ROW
    UPDATE
        products_score 
    SET
        products_score.votes_total =
            (SELECT
                 (votes_1 + votes_2 + votes_3 + votes_4 + votes_5)
             FROM
                 products_score
             WHERE
                 id = new.id);
Nach dem Login kopieren

Beim Versuch, die Tabelle wie folgt zu aktualisieren :

UPDATE products_score SET votes_1 = 5 WHERE id = 0;
Nach dem Login kopieren

Der Trigger schlägt mit dem Fehler fehl:

#1442 - Can't update table 'products_score' in stored function/trigger because it is already used by statement which invoked this stored function/trigger.
Nach dem Login kopieren

Um dieses Problem zu beheben, muss der Trigger in geändert werden Wird vor dem Aktualisierungsereignis ausgeführt und nicht danach. Dadurch kann der Auslöser die Tabelle aktualisieren, bevor die ursprüngliche Aktualisierungsanweisung angewendet wird:

CREATE TRIGGER upd_total_votes BEFORE UPDATE ON products_score
FOR EACH ROW
BEGIN
    SET new.votes_total = new.votes_1 + new.votes_2 + new.votes_3 + new.votes_4 + new.votes_5;
END;
Nach dem Login kopieren

Mit dieser Änderung löst die Aktualisierung der Tabelle wie zuvor erfolgreich eine Aktualisierung der Spalte votes_total aus.

Das obige ist der detaillierte Inhalt vonWie kann ich die Fehlermeldung „Tabelle in gespeicherter Funktion/gespeichertem Trigger kann nicht aktualisiert werden' verhindern, wenn ich After-Update-Trigger verwende?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage