![]() |
Datenbank: Firebird • Version: 2.1 • Zugriff über: IBEASY+
Firebird Db Trigger Problem
Hallöchen
ich komme grad irgendwie nicht weiter. Ich habe einen Generator sowie einen Trigger mittels IBEasy angelegt. Wenn ich nun in der betreffenden Tabelle einen neuen DS anlege passiert: nichts.
Code:
BEFORE INSERT und AKTIV sind eingesetzt.
as
begin if ((new.ID is null) or (new.ID = 0)) then begin new.ID = gen_id( GENTEST, 1 ); end end Meiner Meinung nach ist die Tabelle in Ordnung und der Generator auch. Trotzdem wird keine ID angelegt wenn ein neuer DS angelegt wird (im IBEasy). Mache ich was falsch? Grüße |
AW: Firebird Db Trigger Problem
Der Wert wird erst beim Post gesetzt. Bei der Neuanlage ( + o.aä; kenne IBEasy nicht) bleibt das Feld ersteinmal lle (NULL).
Der Trigger wirkt auch nur wenn man diesen Wert nicht vor dem Abschliessen ändert ( oder mit 0 belegt) |
AW: Firebird Db Trigger Problem
Danke Markus
das hatte ich auch gedacht aber beim Post meckert er rum dass ID nicht leer sein darf. Also greift irgendwie der Trigger nicht. Wo kann ich noch nachsehen? |
AW: Firebird Db Trigger Problem
Ich glaube eher, dass dies ein Problem des Tools ist. Gib mal 0 an.
|
AW: Firebird Db Trigger Problem
Daran habe ich auch schon gedacht und
ein bissl herumgespielt, allerdings ohne Ergebnis. Vllt. sollte ich eine andere GUI suchen. Es gibt ja mehrere für FB. Danke erstmal. |
AW: Firebird Db Trigger Problem
Hi,
du könnest mit dir auch "von Hand" eine neue ID holen und diese dem Insert gleich mitgeben.
SQL-Code:
Das hat den Vorteil, dass für evt. Detail-Datensätze
select
gen_id( GEN_DeineTabelle_ID, 1 ) as NeueID from RDB$Database gleich eine Master_ID bekannt ist. alex |
AW: Firebird Db Trigger Problem
Das kann man aber auch durch RETURNING erreichen
|
AW: Firebird Db Trigger Problem
Danke für Eure Antworten
Ich hatte mich auch schon damit beschäftigt ![]() es ist halt ein Umdenken nötig wenn man vorher nur Jet/Access benutzt hat. Aber ist
Code:
auch Multiuser tauglich?
select
gen_id( GEN_DeineTabelle_ID, 1 ) as NeueID from RDB$Database Ich werde mit einer Testanwendung erstmal sehen ob IBEasy nicht triggert oder ob es in der DB ein Problem gibt. Grüße & Danke |
AW: Firebird Db Trigger Problem
Zitat:
|
AW: Firebird Db Trigger Problem
Zitat:
auch das Insert geschickt wird oder eine eigene? Nutzt man evtl. dafür die TZUpdateSQL ( die für mich immer noch rätselhaft ist). Grüße |
Alle Zeitangaben in WEZ +1. Es ist jetzt 21:35 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