AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi [MySQL]Nächster auto_increment Wert?
Thema durchsuchen
Ansicht
Themen-Optionen

[MySQL]Nächster auto_increment Wert?

Ein Thema von Aenogym · begonnen am 6. Apr 2006 · letzter Beitrag vom 7. Apr 2006
 
Benutzerbild von Jelly
Jelly

Registriert seit: 11. Apr 2003
Ort: Moestroff (Luxemburg)
3.741 Beiträge
 
Delphi 2007 Professional
 
#11

Re: [MySQL]Nächster auto_increment Wert?

  Alt 7. Apr 2006, 20:51
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.
  Mit Zitat antworten Zitat
 


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 04:27 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-2025 by Thomas Breitkreuz