Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi Interbase-Tabelle mit AutoInc-Feld nach Post refreshen? (https://www.delphipraxis.net/31102-interbase-tabelle-mit-autoinc-feld-nach-post-refreshen.html)

Stevie 4. Okt 2004 14:39


Interbase-Tabelle mit AutoInc-Feld nach Post refreshen?
 
Hi Leute,

ich habe eine Firebird 1.5.1 Datenbank mit einer Tabelle, die als PrimaryKey ein AutoInc-Feld hat. Dieses wird über einen BeforeInsert-Trigger und einen Generator gefüllt. Wenn ich über die TIBTable einen neuen Datensatz einfüge, will ich aber die erstellte ID zurückerhalten. Ich habe ForcedRefresh auf True gesetzt, aber ich erhalte den Wert für das AutoInc-Feld nicht zurück. Der Wert muss auf dem Server durch den Trigger erzeugt werden! Ich hab es auch schon mit TIBDataSet und der Eigenschaft RefreshSQL ausprobiert, aber der Datensatz muss anhand der erstellten ID identifiziert werden, aber die ist ja noch nicht bekannt, deshalb würde in der WHERE-Klausel ja auf NULL geprüft, und dann ist der Wert ja schon drin... Wie kann ich es bewerkstelligen, dass ich den Wert zurückerhalte?

MrSpock 4. Okt 2004 14:55

Re: Interbase-Tabelle mit AutoInc-Feld nach Post refreshen?
 
Hallo Stevie,

das Thema hatten wir schon einmal hier.

UweR 4. Okt 2004 14:59

Re: Interbase-Tabelle mit AutoInc-Feld nach Post refreshen?
 
Hallo Stevie,

ich glaube bei den IBX-Komponenten geht das nur wenn du dir die neue ID selbst per Generator erzeugst und im AfterInsert-Ereignis zuweist, bin mir aber nicht ganz sicher.

Ich selbst nehme FIBPlus-Komponenten für den Zugriff auf Interbase/Firebird. Die kriegen das ganz ohne Probleme gebacken. Einfach Generator dem Feld zuweisen, dem Dataset noch sagen wann er sich den wert holen soll (nie, vorm anlegen oder vorm speichern) und man hat keinerlei Refresh-Probleme.

Stevie 4. Okt 2004 15:59

Re: Interbase-Tabelle mit AutoInc-Feld nach Post refreshen?
 
@MrSpock: Eigentlich bin ich ja auch Verfechter der Suchfunktion, aber da ist mir wohl einer durch die Lappen gegangen... :duck:
Hmm, irgendwie kann ich mich aber nicht mit dem Gedanken anfreunden, ne Prozedur zu basteln, die das mit dem Index erledigt...
Ich hab jetzt RefreshSQL so definiert (ich vermute einfach mal, dass zwischen dem insert und dem refresh kein anderes insert sein kann, oder!?):
SQL-Code:
SELECT *
FROM tabelle
WHERE
  id = COALESCE(:id, GEN_ID(tabelle_seq, 0))
@UweR: Sorry, ich bekomm's nicht hin... Irgendwie find ich die FIBPlus-Kompos auch nicht so toll, sollen die besser sein, als die IB-Kompos? :gruebel:
P.S. Sorry, ich hatte das Design-Package nicht installiert, deshalb fehlten die ganzen Editoren... :oops:

UweR 4. Okt 2004 20:17

Re: Interbase-Tabelle mit AutoInc-Feld nach Post refreshen?
 
Hallo Stevie,

die FIBPlus-Komponenten haben meiner Meinung nach einige Vorteile:

Du kriegst die AutoInkrement-Felder ohne Verrenkungen hin.

Du kannst dir clientseitig noch Filter setzen und umsortieren ohne den SQL-server zu bemühen.

Du hast innerhalb eines DataSet's getrennte Transaktionen für SELECT und INSERT/UPDATE

Sie haben aber leider auch einen großen Nachteil. Sie kosten halt entweder Schotter oder laufen außerhalb der IDE nur mit einem dezenten Hinweis.


Alle Zeitangaben in WEZ +1. Es ist jetzt 21:49 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