Delphi-PRAXiS
Seite 1 von 4  1 23     Letzte »    

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Firebird Db Trigger Problem (https://www.delphipraxis.net/171209-firebird-db-trigger-problem.html)

Privateer3000 25. Okt 2012 23:23

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:
as
begin
  if ((new.ID is null) or (new.ID = 0)) then
  begin
    new.ID = gen_id( GENTEST, 1 );
  end
end
BEFORE INSERT und AKTIV sind eingesetzt.
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

mkinzler 26. Okt 2012 05:20

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)

Privateer3000 26. Okt 2012 11:27

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?

mkinzler 26. Okt 2012 11:30

AW: Firebird Db Trigger Problem
 
Ich glaube eher, dass dies ein Problem des Tools ist. Gib mal 0 an.

Privateer3000 26. Okt 2012 11:58

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.

alex517 26. Okt 2012 13:49

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:
select
   gen_id( GEN_DeineTabelle_ID, 1 ) as NeueID
from
  RDB$Database
Das hat den Vorteil, dass für evt. Detail-Datensätze
gleich eine Master_ID bekannt ist.

alex

mkinzler 26. Okt 2012 13:50

AW: Firebird Db Trigger Problem
 
Das kann man aber auch durch RETURNING erreichen

Privateer3000 26. Okt 2012 16:50

AW: Firebird Db Trigger Problem
 
Danke für Eure Antworten
Ich hatte mich auch schon damit beschäftigt
http://www.firebirdsql.org/manual/de...rguide-de.html
es ist halt ein Umdenken nötig wenn man vorher nur Jet/Access benutzt hat.
Aber ist
Code:
select
    gen_id( GEN_DeineTabelle_ID, 1 ) as NeueID
from
  RDB$Database
auch Multiuser tauglich?
Ich werde mit einer Testanwendung erstmal
sehen ob IBEasy nicht triggert oder ob es in der DB ein Problem gibt.
Grüße & Danke

mkinzler 26. Okt 2012 17:58

AW: Firebird Db Trigger Problem
 
Zitat:

... auch Multiuser tauglich?
Ja deenn diese wird durch die semaphoren-gestützte Funktion gen_id(() gewährleistet

Privateer3000 27. Okt 2012 09:37

AW: Firebird Db Trigger Problem
 
Zitat:

Zitat von alex517 (Beitrag 1188495)
Hi,

du könnest mit dir auch "von Hand" eine neue ID holen
und diese dem Insert gleich mitgeben.

SQL-Code:
select
   gen_id( GEN_DeineTabelle_ID, 1 ) as NeueID
from
  RDB$Database
Das hat den Vorteil, dass für evt. Detail-Datensätze
gleich eine Master_ID bekannt ist.

alex

Schickt man das mit der gleichen TZSQL mit der
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 23:30 Uhr.
Seite 1 von 4  1 23     Letzte »    

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz