Heim >Datenbank >MySQL-Tutorial >So erstellen und löschen Sie MySQL-Trigger

So erstellen und löschen Sie MySQL-Trigger

WBOY
WBOYnach vorne
2023-05-28 16:34:111058Durchsuche

So erstellen und löschen Sie MySQL-Trigger

1. Warum brauchen wir Trigger?

Einige Tabellen hängen miteinander zusammen, z. B. die Produkttabelle und die Inventartabelle. Wenn wir die Daten der Produkttabelle bearbeiten, muss sich die entsprechende Inventartabelle ändern. damit wir die Datenintegrität gewährleisten können. Es wäre problematischer, wenn wir es selbst manuell pflegen würden.
Zu diesem Zeitpunkt können wir Trigger verwenden, um einen Trigger zu erstellen, sodass der Einfügevorgang von Produktinformationsdaten automatisch den Einfügevorgang von Bestandsdaten usw. auslöst, sodass wir uns keine Sorgen über Datenverlust machen müssen, weil wir das Hinzufügen vergessen haben Bestandsdaten. 2. Überblick über Trigger Ereignis. Zu diesen Ereignissen gehören Einfüge-, Lösch- und Aktualisierungsereignisse. Wenn die Datenbank diese Anweisungen ausführt, entspricht dies dem Auftreten eines Ereignisses und die entsprechenden Vorgänge werden automatisch ausgelöst Wenn Sie beim Einfügen von Daten in eine Tabelle in der Datenbank automatisch eine Datenbanklogik ausführen müssen, können wir dies mithilfe von Triggern erreichen.

    3. Erstellung von Triggern
  • 3.1 Syntax

  • Trigger wirken sich auf die Tabelle aus. Wir möchten beispielsweise, dass die Ausführung des Triggers ausgelöst wird, wenn ein neuer Datensatz zu Tabelle A hinzugefügt wird der Trigger. Ob der Trigger vor oder nach der Ausführung der Einfügeanweisung ausgeführt wird.
  • für jede Zeile gibt an, dass jedes Mal, wenn ein Ereignis (Einfügen, Aktualisieren oder Löschen) ausgeführt wird, ein Trigger ausgelöst wird
  • CREATE TRIGGER 触发器名称 
    {BEFORE|AFTER} {INSERT|UPDATE|DELETE} ON 表名 
    FOR EACH ROW 触发器执行的语句块;
  • Beschreibung:
  • Tabellenname: gibt an ein Trigger Überwachte Objekte.
  • VOR|NACH: Gibt die Auslösezeit an. BEFORE bedeutet Trigger vor dem Ereignis; AFTER bedeutet Trigger nach dem Ereignis.

INSERT|UPDATE|DELETE: Zeigt das ausgelöste Ereignis an.

      INSERT bedeutet Auslösen, wenn ein Datensatz eingefügt wird;
    • UPDATE bedeutet Auslösen, wenn ein Datensatz aktualisiert wird;

      DELETE bedeutet Auslösen, wenn ein Datensatz gelöscht wird .
    • 表名:表示触发器监控的对象。

    • BEFORE|AFTER:表示触发的时间。BEFORE 表示在事件之前触发;AFTER 表示在事件之后触发。

    • INSERT|UPDATE|DELETE:表示触发的事件。

      • INSERT 表示插入记录时触发;

      • UPDATE 表示更新记录时触发;

      • DELETE 表示删除记录时触发。

    • 触发器执行的语句块

    • Durch Trigger ausgeführter Anweisungsblock: Es kann sich um eine einzelne SQL-Anweisung oder einen zusammengesetzten Anweisungsblock handeln, der aus der Struktur BEGIN...END besteht.

    3.2 Falldemonstration

    Bereiten Sie zuerst die Tabelle vor

    CREATE TABLE test_trigger (id INT PRIMARY KEY AUTO_INCREMENT,t_note VARCHAR(30));CREATE TABLE test_trigger_log (id INT PRIMARY KEY AUTO_INCREMENT,t_log VARCHAR(30));
    So erstellen und löschen Sie MySQL-TriggerAnforderungen: Erstellen Sie einen Trigger: Erstellen Sie einen Trigger mit dem Namen before_insert. Bevor Sie Daten in die Datentabelle test_trigger einfügen, fügen Sie die Protokollinformationen before_insert in die Datentabelle test_trigger_log ein.
    So erstellen und löschen Sie MySQL-Trigger

      4. Trigger anzeigen
    • Beim Anzeigen von Triggern werden die Definition, der Status und die Syntaxinformationen von Triggern angezeigt, die bereits in der Datenbank vorhanden sind
    • Methode 1: Alle Trigger in der aktuellen Datenbankdefinition anzeigen

    So erstellen und löschen Sie MySQL-Trigger

    show triggers\G 注意,在SQLyog中,不能加上\G

    • Methode 2: Sehen Sie sich die Definition eines Triggers in der aktuellen Datenbank an

    So erstellen und löschen Sie MySQL-Trigger

    show create trigger 触发器名

    • Methode 3: Fragen Sie den Trigger „salary_check_trigger“ aus den TRIGGERS ab Tabelle der Systembibliothek information_schema Triggerinformationen

    SELECT * FROM information_schema.TRIGGERS;

    5. Trigger löschen

    🎜Trigger sind ebenfalls Datenbankobjekte und Trigger werden auch mit der Drop-Anweisung gelöscht🎜
    drop trigger if exists 触发器名;

Das obige ist der detaillierte Inhalt vonSo erstellen und löschen Sie MySQL-Trigger. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:yisu.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen