Trigger werden ausgeführt, wenn in einer Tabelle ein Ereignis ausgelöst wird.
Konkret heißt das, dass bei einem INSERT,UPDATE oder DELETE wir eingreifen können und einen oder mehrere Befehle “danach” oder “anstelle” von ausführen können.
1 2 3 4 5 6 |
CREATE TRIGGER tr_TRIGGERNAME ON TABELLE_DIE_ÜBERWACHT WIRD AFTER / INSTEAD OF INSERT,UPDATE, DELETE AS DECLARE @test_variable varchar(max) = 'test' BEGIN print 'abc' END |
Wählen wir AFTER, dann wird der Datensatz erstellt/geupdated oder gelöscht und erst dann greift der Trigger ein.
Wählen wir stattdessen Instead Of, wird anstelle von dem Insert, Update oder Delete der Trigger ausgeführt.
Beim Trigger stehen uns 2 weitere Temporäre Tabellen zur Verfügung, nämlich inserted und deleted.
wenn wir z.B. einen neuen Datensatz id, Vorname, Nachname in die Datenbank geschrieben haben,
so können wir aus dem Trigger mit
1 |
Select id from inserted |
die Id, die gerade eben eingetragen wurde abfragen.
Machen wir ein Update, so wird der alte Datensatz erst einmal erst in die temporäre Tabelle deleted gesteckt, welchen
wir ebenso mit
1 |
Select Name from deleted |
abfragen könnten.
Login