![]() |
AW: Firebird Db Trigger Problem
Zitat:
Das mit den Generatoren und Timestamp : auch gleich vergessen. Generator=Ganzzahl (integer oder Bigint). Perlsau hat wohl Generatoren und Trigger verwechselt. :stupid: Wenn ich nämlich z.B. ein Feld ANGELEGT in meiner Tabelle habe, dann hindert mich keiner dran, folgende Zeilen (hier in einem Insert-Trigger) hinzuzufügen:
Code:
IF (NEW.ANGELEGT IS NULL) THEN
NEW.ANGELEGT = CURRENT_TIMESTAMP; |
AW: Firebird Db Trigger Problem
Vielen Dank @alle
das muss ich erstmal gut kauen und verdauen. Langsam finde ich Gefallen an den Triggern :) |
AW: Firebird Db Trigger Problem
Zitat:
Ruft nicht ein OnAfterUpdate-Trigger sich selbst wieder auf, wenn darin ein Update vorgenommen wird? Das würde dann doch eine Endlos-Schleife ergeben ... |
AW: Firebird Db Trigger Problem
Update ? Ja, After-Update-Trigger. Ungefähr so :
Code:
Der Trigger macht doch das Update schon. Das Delphi-Dataset stösst ja das Update an, aber nicht für das Feld LETZTEAENDERUNG. Das darf im Programm nicht besetzt werden, damit der Trigger richtig zuschlägt.
UPDATE TABELLE SET
LETZTEAENDERUNG = CURRENT_TIMESTAMP WHERE (ID = OLD.ID) AND ((LETZTEAENDERUNG IS NULL) OR (LETZTEAENDERUNG <> CURRENT_TIMESTAMP)); |
AW: Firebird Db Trigger Problem
Zitat:
|
AW: Firebird Db Trigger Problem
Zitat:
Code:
Wozu sollte hier noch ein erneutes Update gemacht werden?
CREATE TRIGGER TABELLE_BU FOR TABELLE
ACTIVE BEFORE UPDATE POSITION 1 AS BEGIN new.LETZTEAENDERUNG = CURRENT_TIMESTAMP; END |
AW: Firebird Db Trigger Problem
Na ja, man könnte das wohl auch so machen, wenn die WHERE - Klausel nicht wichtig ist. Minimalistischer gehts nimmer. :lol:
Das Beispiel gilt für folgenden Fall : 1. das Feld LETZTEAENDERUNG ist noch nicht besetzt : Datensatz wurde also noch nie geändert. Wird über IS NULL geprüft. Feld wird dann besetzt. 2. LETZTEAENDERUNG ist schon bestückt. Z.B. von Hand, maschinell aus alten Datenbeständen oder eben durch ein vorhergehendes Update. Nur mit IS NULL würde LETZTEAENDERUNG nur bei dem allerersten Update aktualisiert und danach nie mehr ! Also wird noch eine Bedingung gebraucht, dei für NOT IS NULL gilt ! Bitte vor Kommentaren genau lesen ! Das ist logisch nicht so einfach zusammenzubauen, wie es auf den ersten Blick aussieht ! Nebenbei bemerkt, man muss sich die Trigger wie Kettenhunde vorstellen. Der von TBx ist dabei vollständig von der Kette gelassen und beisst immer zu, ohne wenn und aber. Meiner ist etwas gezähmt. |
AW: Firebird Db Trigger Problem
Im Normalfall ist es auch gewollt das im Feld die letzte Änderung eines Datensatzes steht. Ich würde also wie TBX vom Normalfall ausgehen und nicht den Sonderfall bearbeiten, dass dies nur unter bestimmten Bedingungen gelten soll. Zudem mir die Sinnhaftigkeit deines Vergleiches nicht ganz einleuten will. ( Da ein CURRENT_TIMESTAMP nie NULL ist, ist der erste Teil der Bedingung überflüssig und wenn zufällig schon der gleiche Wert da stehen sollte [ was sehr unwahscheinlich ist] schadet es nicht diesen zu überschreiben).
Ich würde auch wie Thomas den BeforeInsert-Trigger bevorzugen, da der Timestamp ja zu diesem Vorgang gehört und sich auf die selbe Tabelle bezieht ( keine Logvorgang o.ä). |
AW: Firebird Db Trigger Problem
Zitat:
|
AW: Firebird Db Trigger Problem
Zitat:
Magst Du mal die genaue Meldung posten? Hast Du noch weitere Trigger auf der Tabelle definiert? |
Alle Zeitangaben in WEZ +1. Es ist jetzt 04:03 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz