Delphi-PRAXiS
Seite 2 von 2     12   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi [MySQL]Nächster auto_increment Wert? (https://www.delphipraxis.net/66927-%5Bmysql%5Dnaechster-auto_increment-wert.html)

Jelly 7. Apr 2006 20:51

Re: [MySQL]Nächster auto_increment Wert?
 
Zitat:

Zitat von mkinzler
Die neueste Version von Zeos unterstützt sequences, die genau für das da sind. Hierüber kannst du den letzten vergebenen Wert der Sequenz, sowie den nächsten zu vergebenen Wert abfragen. Ich arbeite nicht mit mysql und weiß daher nicht, ob es hiermit funktioniert

Lass mich raten... Du arbeitest mit Postgres SQL :-)

Aber das Problem ist nicht neu, und eigentlich gar nich so leicht zu lösen in einer Mehrbenutzerumgebung. Auch wenn man direkt den Record mit einem einzigen Transaction Befehl einfügt, muss man anschliessend ein Select aufrufen, um den letzten Record zu erhalten. Und in der Zwischenzeit kann ein anderer User schon wieder bereits einen Record eingefügt haben. Auch der Weg über LAST_INSERT_ID() bringt da nichts, da eben gerade diese "Sequenzen" transaktionsunabhängig ablaufen.

Der einzige, sichere Weg, der mir einfällt, ist sich vorher eine ID aus dem Pool zu holen, und diese dann auch zu verwenden... Bei Postgres geht das in der Tat mit getnextval, in Firebird ginge das mit dem Auslesen eines Generators.

mkinzler 7. Apr 2006 21:14

Re: [MySQL]Nächster auto_increment Wert?
 
Zitat:

Zitat von Jelly
Lass mich raten... Du arbeitest mit Postgres SQL Smile

Nein FireBird. Ich habe dieses Feature unter Zeos noch nicht verwendet, da neben den Sequences der "alter" fb-spezifische Weg über Generatoren noch möglich ist.

Basilikum 7. Apr 2006 21:48

Re: [MySQL]Nächster auto_increment Wert?
 
Zitat:

Zitat von Jelly
Aber das Problem ist nicht neu, und eigentlich gar nich so leicht zu lösen in einer Mehrbenutzerumgebung. Auch wenn man direkt den Record mit einem einzigen Transaction Befehl einfügt, muss man anschliessend ein Select aufrufen, um den letzten Record zu erhalten. Und in der Zwischenzeit kann ein anderer User schon wieder bereits einen Record eingefügt haben. Auch der Weg über LAST_INSERT_ID() bringt da nichts, da eben gerade diese "Sequenzen" transaktionsunabhängig ablaufen.

dass die Variante ala SELECT MAX(ID) nichts ist, bin ich einverstanden - mit LAST_INSERT_ID() funktioniert dies jedoch einwandfrei, da LAST_INSERT_ID() nicht die global letzte ID zurückgibt, sondern die tatsächlich für diesen Client verwendete (insofern also auch in Mehrbenutzer-Umgebung absolut zuverlässig):
Zitat:

Zitat von 22.2.13.3. How to Get the Unique ID for the Last Inserted Row
For LAST_INSERT_ID(), the most recently generated ID is maintained in the server on a per-connection basis. It is not changed by another client. It is not even changed if you update another AUTO_INCREMENT column with a non-magic value (that is, a value that is not NULL and not 0).


Jelly 7. Apr 2006 22:04

Re: [MySQL]Nächster auto_increment Wert?
 
OK, überzeugt... Dann ist das imho der einzige Weg sicherzustellen, die wirklich erhaltene ID zu bekommen.

Igotcha 7. Apr 2006 22:12

Re: [MySQL]Nächster auto_increment Wert?
 
Zitat:

Zitat von Jelly
OK, überzeugt... Dann ist das imho der einzige Weg sicherzustellen, die wirklich erhaltene ID zu bekommen.

Wie ich auch bereits oben schon geschrieben hatte ;-)


Alle Zeitangaben in WEZ +1. Es ist jetzt 08:53 Uhr.
Seite 2 von 2     12   

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