PostgreSQL Auslöser: Erstellen, Auflisten und Löschen mit Beispiel
Was ist Trigger? PostgreSQL?
A PostgreSQL Auslösen ist eine Funktion, die automatisch ausgelöst wird, wenn ein Datenbankereignis für ein Datenbankobjekt auftritt. Zum Beispiel ein Tisch. Beispiele für Datenbankereignisse, die einen Trigger aktivieren können, sind INSERT, UPDATE, DELETE usw. Wenn Sie außerdem einen Trigger für eine Tabelle erstellen, wird der Trigger automatisch gelöscht, wenn diese Tabelle gelöscht wird.
Wie Trigger verwendet wird PostgreSQL?
Ein Trigger kann während seiner Erstellung mit dem Operator FOR EACH ROW gekennzeichnet werden. Ein solcher Trigger wird einmal für jede durch die Operation geänderte Zeile aufgerufen. Ein Trigger kann während seiner Erstellung auch mit dem Operator FOR EACH STATEMENT gekennzeichnet werden. Dieser Trigger wird nur einmal für eine bestimmte Operation ausgeführt.
PostgreSQL erstellen Auslöser
Um einen Trigger zu erstellen, verwenden wir die Funktion CREATE TRIGGER. Hier ist die Syntax für die Funktion:
CREATE TRIGGER trigger-name [BEFORE|AFTER|INSTEAD OF] event-name ON table-name [ -- Trigger logic ];
Der Triggername ist der Name des Triggers.
BEFORE, AFTER und INSTEAD OF sind Schlüsselwörter, die bestimmen, wann der Trigger aufgerufen wird.
Der Ereignisname ist der Name des Ereignisses, das den Auslöser auslöst. Das kann sein INSERT, AKTUALISIEREN, LÖSCHEN usw.
Der Tabellenname ist der Name der Tabelle, für die der Trigger erstellt werden soll.
Wenn der Trigger für eine INSERT-Operation erstellt werden soll, müssen wir den Spaltenname-Parameter ON hinzufügen.
Die folgende Syntax veranschaulicht dies:
CREATE TRIGGER trigger-name AFTER INSERT ON column-name ON table-name [ -- Trigger logic ];
PostgreSQL Erstellen Sie ein Trigger-Beispiel
Wir verwenden die unten angegebene Preistabelle:
Preis:
Erstellen wir eine weitere Tabelle, Price_Audits, in der wir die an der Preistabelle vorgenommenen Änderungen protokollieren:
CREATE TABLE Price_Audits ( book_id INT NOT NULL, entry_date text NOT NULL );
Wir können jetzt eine neue Funktion namens auditfunc definieren:
CREATE OR REPLACE FUNCTION auditfunc() RETURNS TRIGGER AS $my_table$ BEGIN INSERT INTO Price_Audits(book_id, entry_date) VALUES (new.ID, current_timestamp); RETURN NEW; END; $my_table$ LANGUAGE plpgsql;
Die obige Funktion fügt einen Datensatz in die Tabelle Price_Audits ein, einschließlich der neuen Zeilen-ID und der Zeit, zu der der Datensatz erstellt wurde.
Da wir nun die Triggerfunktion haben, sollten wir sie an unsere Preistabelle binden. Wir geben dem Trigger den Namen price_trigger. Bevor ein neuer Datensatz erstellt wird, wird die Triggerfunktion automatisch aufgerufen, um die Änderungen zu protokollieren. Hier ist der Auslöser:
CREATE TRIGGER price_trigger AFTER INSERT ON Price FOR EACH ROW EXECUTE PROCEDURE auditfunc();
Fügen wir einen neuen Datensatz in die Preistabelle ein:
INSERT INTO Price VALUES (3, 400);
Nachdem wir nun einen Datensatz in die Tabelle „Price“ eingefügt haben, sollte auch ein Datensatz in die Tabelle „Price_Audit“ eingefügt werden. Dies ist auf den Auslöser zurückzuführen, den wir in der Preistabelle erstellt haben. Lassen Sie uns Folgendes überprüfen:
SELECT * FROM Price_Audits;
Dies gibt Folgendes zurück:
Der Auslöser hat erfolgreich funktioniert.
Postgres-Listenauslöser
Alle Trigger, die Sie erstellen PostgreSQL werden in der pg_trigger-Tabelle gespeichert. Um die Liste der Trigger anzuzeigen, die Sie haben Datenbank, fragen Sie die Tabelle ab, indem Sie den SELECT-Befehl wie unten gezeigt ausführen:
SELECT tgname FROM pg_trigger;
Dies gibt Folgendes zurück:
Die tgname-Spalte der pg_trigger-Tabelle gibt den Namen des Triggers an.
Postgres-Drop-Trigger
Um einen fallen zu lassen PostgreSQL Trigger verwenden wir die DROP TRIGGER-Anweisung mit der folgenden Syntax:
DROP TRIGGER [IF EXISTS] trigger-name ON table-name [ CASCADE | RESTRICT ];
Der Parameter trigger-name gibt den Namen des Triggers an, der gelöscht werden soll.
Der Tabellenname gibt den Namen der Tabelle an, aus der der Trigger gelöscht werden soll.
Die IF EXISTS-Klausel versucht, einen vorhandenen Trigger zu löschen. Wenn Sie versuchen, einen Trigger zu löschen, der nicht vorhanden ist, ohne die IF EXISTS-Klausel zu verwenden, erhalten Sie eine Fehlermeldung.
Mit der CASCADE-Option können Sie alle Objekte, die vom Auslöser abhängen, automatisch löschen.
Wenn Sie die Option RESTRICT verwenden, wird der Trigger nicht gelöscht, wenn Objekte davon abhängig sind.
Zum Beispiel:
Um den Trigger mit dem Namen example_trigger in der Tabelle Price zu löschen, führen wir den folgenden Befehl aus:
Um den Trigger mit dem Namen example_trigger in der Tabelle Company abzulegen, führen Sie den folgenden Befehl aus:
DROP TRIGGER example_trigger IF EXISTS ON Company;
Verwenden von pgAdmin
Sehen wir uns nun an, wie alle drei Aktionen mit pgAdmin ausgeführt wurden.
So erstellen Sie einen Trigger in PostgreSQL mit pgAdmin
So können Sie mit pgAdmin einen Trigger in Postgres erstellen:
Schritt 1) Melden Sie sich bei Ihrem pgAdmin-Konto an
Öffnen Sie pgAdmin und melden Sie sich mit Ihren Anmeldeinformationen bei Ihrem Konto an
Schritt 2) Erstellen Sie eine Demo-Datenbank
- Klicken Sie in der Navigationsleiste links auf Datenbanken.
- Klicken Sie auf Demo.
Schritt 3) Geben Sie die Abfrage ein
Um die Tabelle Price_Audits zu erstellen, geben Sie die Abfrage im Editor ein:
CREATE TABLE Price_Audits ( book_id INT NOT NULL, entry_date text NOT NULL )
Schritt 4) Führen Sie die Abfrage aus
Klicken Sie auf die Schaltfläche „Ausführen“.
Schritt 5) Führen Sie den Code für auditfunc aus
Führen Sie den folgenden Code aus, um die Funktion auditfunc zu definieren:
CREATE OR REPLACE FUNCTION auditfunc() RETURNS TRIGGER AS $my_table$ BEGIN INSERT INTO Price_Audits(book_id, entry_date) VALUES (new.ID, current_timestamp); RETURN NEW; END; $my_table$ LANGUAGE plpgsql
Schritt 6) Führen Sie den Code aus, um einen Trigger zu erstellen
Führen Sie den folgenden Code aus, um den Trigger price_trigger zu erstellen:
CREATE TRIGGER price_trigger AFTER INSERT ON Price FOR EACH ROW EXECUTE PROCEDURE auditfunc()
Schritt 7) Fügen Sie einen neuen Datensatz ein
- Führen Sie den folgenden Befehl aus, um einen neuen Datensatz in die Preistabelle einzufügen:
INSERT INTO Price VALUES (3, 400)
- Führen Sie den folgenden Befehl aus, um zu überprüfen, ob ein Datensatz in die Tabelle Price_Audits eingefügt wurde:
SELECT * FROM Price_Audits
Dies sollte Folgendes zurückgeben:
Schritt 8) Überprüfen Sie den Tabelleninhalt
Lassen Sie uns den Inhalt der Tabelle Price_Audits überprüfen:
Auflisten von Triggern mit pgAdmin
Schritt 1) Führen Sie den folgenden Befehl aus, um die Trigger in Ihrer Datenbank zu überprüfen:
SELECT tgname FROM pg_trigger
Dies gibt Folgendes zurück:
Löschen von Triggern mit pgAdmin
Um den Trigger mit dem Namen example_trigger in der Tabelle Company abzulegen, führen Sie den folgenden Befehl aus:
DROP TRIGGER example_trigger IF EXISTS ON Company
Zusammenfassung
- A PostgreSQL Trigger bezieht sich auf eine Funktion, die automatisch ausgelöst wird, wenn ein Datenbankereignis für ein Datenbankobjekt, beispielsweise eine Tabelle, auftritt.
- Beispiele für solche Datenbankereignisse sind INSERT, UPDATE, DELETE usw.
- Ein Trigger existiert nur während der Lebensdauer des Datenbankobjekts, für das er erstellt wurde.
- Wenn das Datenbankobjekt gelöscht wird, wird auch der Trigger gelöscht.
- PostgreSQL Trigger werden mit der CREATE TRIGGER-Anweisung erstellt.
- Jeder Trigger ist mit einer Funktion verknüpft, die angibt, was der Trigger tun wird, wenn er aufgerufen wird.
Laden Sie die in diesem Tutorial verwendete Datenbank herunter