Heim > Datenbank > MySQL-Tutorial > Wie behebt man den Fehler „Tabelle kann nicht aktualisiert werden, da sie bereits verwendet wird' in MySQL-Triggern?

Wie behebt man den Fehler „Tabelle kann nicht aktualisiert werden, da sie bereits verwendet wird' in MySQL-Triggern?

Patricia Arquette
Freigeben: 2024-12-27 18:51:13
Original
809 Leute haben es durchsucht

How to Resolve

Trigger-Unterbrechung beim Aktualisieren der Tabelle: Beheben des Problems

Bei der Datenbankprogrammierung ist es manchmal erforderlich, die Spalte einer Tabelle anschließend mithilfe eines Triggers zu aktualisieren ein Aktualisierungsvorgang für dieselbe Tabelle. Dies kann jedoch zu einem Fehler führen, wenn der Trigger versucht, die Tabelle zu aktualisieren, während sie bereits aktualisiert wird.

Beachten 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

Wenn ein Aktualisierungsvorgang mit ausgeführt wird Bei diesem Trigger wird der Fehler „#1442 – Tabelle ‚products_score‘ in der gespeicherten Funktion/dem gespeicherten Trigger kann nicht aktualisiert werden, da sie bereits von der Anweisung verwendet wird, die diese gespeicherte Funktion/der gespeicherte Trigger aufgerufen hat“ angezeigt aufgetreten.

Um dieses Problem zu beheben, ändern Sie den Triggerzeitpunkt auf VORHER statt NACHHER. Dadurch kann der Trigger vor dem Aktualisierungsvorgang ausgeführt werden, wodurch vermieden wird, dass die Tabelle während der Aktualisierung gesperrt wird. Der aktualisierte Trigger sollte wie folgt aussehen:

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 diesem geänderten Trigger kann die Spalte der Tabelle nach dem Aktualisierungsvorgang erfolgreich aktualisiert werden.

Das obige ist der detaillierte Inhalt vonWie behebt man den Fehler „Tabelle kann nicht aktualisiert werden, da sie bereits verwendet wird' in MySQL-Triggern?. 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