Heim > Datenbank > MySQL-Tutorial > Erfahren Sie, wie Sie Trigger in MySQL erstellen und löschen

Erfahren Sie, wie Sie Trigger in MySQL erstellen und löschen

PHPz
Freigeben: 2023-04-19 15:07:15
Original
935 Leute haben es durchsucht

Ein Trigger in MySQL ist eine spezielle Art von gespeicherter Prozedur. Dabei handelt es sich um eine Reihe tabellenbezogener Aktionen, die automatisch ausgeführt werden können, wenn eine vordefinierte Operation ausgeführt wird, beispielsweise wenn eine DELETE-, UPDATE- oder INSERT-Operation für die Tabelle ausgeführt wird. Trigger können Entwicklern flexible Programmieroptionen bieten, indem sie eine spezielle Syntax für die Tabelle definieren. In diesem Artikel erfahren Sie, wie Sie Trigger in MySQL erstellen und löschen.

MySQL-Trigger erstellen

Um einen Trigger in MySQL zu erstellen, müssen Sie die CREATE TRIGGER-Anweisung verwenden. Die Syntax lautet wie folgt:

CREATE TRIGGER trigger_name 
BEFORE|AFTER INSERT|UPDATE|DELETE ON table_name
FOR EACH ROW 
BEGIN 
   -- 触发器执行的操作
END;
Nach dem Login kopieren

Die CREATE TRIGGER-Anweisung muss Folgendes angeben:

  • trigger_name Der Name des auslösen.
  • VOR |. NACHHER Wann dieser Vorgang ausgelöst werden soll.
  • Vorgänge im Zusammenhang mit INSERT|UPDATE|DELETE-Triggern.
  • table_name Der Name der Tabelle, für die der Triggervorgang ausgeführt werden soll.
  • FOR EACH ROW gibt die Anzahl der Zeilen an, die dieser Trigger jedes Mal ausführt.
  • BEGIN und END definieren die SQL-Anweisungen, die im Trigger ausgeführt werden sollen.

Zum Beispiel definiert die folgende CREATE TRIGGER-Anweisung einen Trigger, der ausgeführt wird, wenn eine Datenzeile in die Benutzertabelle eingefügt wird:

CREATE TRIGGER my_trigger 
BEFORE INSERT ON user
FOR EACH ROW
BEGIN
  INSERT INTO user_log (user_id, action) VALUES (NEW.id, 'inserted');
END;
Nach dem Login kopieren

Dieser Trigger wird vor jeder INSERT-Operation in der Benutzertabelle ausgeführt und fügt die Daten-ID ein und Operationstyp (eingefügt) in die Tabelle user_log eingefügt.

MySQL-Trigger löschen

In MySQL erfordert das Löschen von Triggern die Verwendung der DROP TRIGGER-Anweisung. Die Syntax lautet wie folgt:

DROP TRIGGER [IF EXISTS] trigger_name;
Nach dem Login kopieren

Die DROP TRIGGER-Anweisung muss Folgendes angeben:

  • IF EXISTS Wenn diese Option festgelegt ist , wenn Sie versuchen zu löschen. Wenn der Trigger nicht vorhanden ist, wird kein Fehler zurückgegeben.
  • trigger_name Der Name des zu löschenden Triggers.

Hier ist ein praktisches Beispiel: Wenn wir den Trigger my_trigger löschen möchten, können wir die folgende Anweisung verwenden:

DROP TRIGGER IF EXISTS my_trigger;
Nach dem Login kopieren

In der DROP TRIGGER-Anweisung haben wir die Option IF EXISTS verwendet, um sicherzustellen, dass der Trigger, den wir verwenden möchten delete existiert tatsächlich. Wenn wir diese Option nicht verwenden, wird ein Fehler zurückgegeben, wenn wir versuchen, einen nicht vorhandenen Trigger zu löschen.

Zusammenfassung

Trigger in MySQL sind eine konfigurierbare Möglichkeit, Aktionen unter bestimmten Umständen automatisch auszuführen. Trigger können bei BEFORE- oder AFTER-Ereignissen ausgeführt werden, und es können verschiedene Trigger für INSERT-, UPDATE- und DELETE-Vorgänge definiert werden. Um einen MySQL-Trigger zu erstellen, müssen Sie die CREATE TRIGGER-Anweisung verwenden, und um einen Trigger zu löschen, müssen Sie die DROP TRIGGER-Anweisung verwenden. Wenn Sie mehr über MySQL-Trigger erfahren möchten, lesen Sie bitte die offizielle MySQL-Dokumentation.

Das obige ist der detaillierte Inhalt vonErfahren Sie, wie Sie Trigger in MySQL erstellen und löschen. 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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage