AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi SQL Automatisch zugeteilte Id ermitteln.
Thema durchsuchen
Ansicht
Themen-Optionen

SQL Automatisch zugeteilte Id ermitteln.

Ein Thema von Bladefire · begonnen am 12. Jul 2014 · letzter Beitrag vom 14. Jul 2014
Antwort Antwort
Seite 1 von 2  1 2      
supermuckl

Registriert seit: 1. Feb 2003
1.340 Beiträge
 
FreePascal / Lazarus
 
#1

AW: SQL Automatisch zugeteilte Id ermitteln.

  Alt 14. Jul 2014, 12:31
ich hab das problem letztens in postgres so gelöst:

transaction auf
query ausführen
"id des eingefügten records auslesen" query dahinter
transaction zu

damit kommt direkt die neue id als resultset zurück
Unter Umständen könnte das ja auf allen Datenbanken, egal wieviele Benutzer im Moment zugreifen funktionieren? Und auch noch unabhängig von der eingesetzten Schnittstellensoftware?
Das kann nicht sein!

Gruß
K-H
bin ich mir nicht so ganz sicher
aber es gibt halt den weg - und ob der sicher ist, hängt von der implementation der transaktion ab (transaktionsisolation)

begin;
insert into test(name) values ('something');
select CURVAL('test_id_seq');
commit;

und auch den weg (postgresql native) über
"returning"

INSERT INTO t2 (eid, ...) VALUES (...) RETURNING eid;

ob es das bei anderen DBs gibt, weiß ich nicht
Das echte Leben ist was für Leute...
... die im Internet keine Freunde finden!
  Mit Zitat antworten Zitat
Mikkey

Registriert seit: 5. Aug 2013
265 Beiträge
 
#2

AW: SQL Automatisch zugeteilte Id ermitteln.

  Alt 14. Jul 2014, 12:44
@supermuckl

Eine Funktion "CURVAL" dürfte es nicht durchgehend auf allen DBMS geben. Allerdings hatte ich Deinen ersten Beitrag dazu eher so verstanden:

Code:
INSERT INTO table(f1, f2) VALUES(<Schlüsselwert>, 'Blabla');
SELECT <autoincrementfield> FROM table WHERE f1=<Schlüsselwert>
Der Schlüssel muss dann natürlich eindeutig sein.

Das dürfte innerhalb einer Transaktion in jedem DBMS funktionieren, könnte bei manchen (je nach Konfiguration) aber zum Rollback führen, wenn zwei User "gleichzeitig" diese Transaktion durchführen.
  Mit Zitat antworten Zitat
mjustin

Registriert seit: 14. Apr 2008
3.006 Beiträge
 
Delphi 2009 Professional
 
#3

AW: SQL Automatisch zugeteilte Id ermitteln.

  Alt 14. Jul 2014, 12:59

Code:
INSERT INTO table(f1, f2) VALUES(<Schlüsselwert>, 'Blabla');
SELECT <autoincrementfield> FROM table WHERE f1=<Schlüsselwert>
Das dürfte innerhalb einer Transaktion in jedem DBMS funktionieren
Was ist an Stele von <autoincrementfield> denn einzusetzen, das auf jedem DBMS funktioniert?

Code:
SELECT <autoincrementfield> FROM table WHERE f1=<Schlüsselwert>
Wenn das Feld "table.f1" das Primary Key Feld ist, ergibt sich das Problem, dass man den Autonkrementwert nicht kennt, und daher logischerweise auch kein

Code:
SELECT f1 FROM table WHERE f1=<Schlüsselwert>
durchführen kann. Denn <Schlüsselwert> ist bei Autoinkrement-Feldern nicht bekannt (wenn der Wert über einen BEFORE INSERT Trigger unter Verwendung eines Firebird-Generators erzeugt wurde, hat der Client nach Ausführung des INSERT keinen Zugriff auf den soeben erzeugten <Schlüsselwert>).
Michael Justin
  Mit Zitat antworten Zitat
supermuckl

Registriert seit: 1. Feb 2003
1.340 Beiträge
 
FreePascal / Lazarus
 
#4

AW: SQL Automatisch zugeteilte Id ermitteln.

  Alt 14. Jul 2014, 13:04
der TE könnte ja mal erzählen, was für eine DB er einsetzt.

//edit
da stehts mysql..
Das echte Leben ist was für Leute...
... die im Internet keine Freunde finden!

Geändert von supermuckl (14. Jul 2014 um 13:48 Uhr)
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.851 Beiträge
 
Delphi 11 Alexandria
 
#5

AW: SQL Automatisch zugeteilte Id ermitteln.

  Alt 14. Jul 2014, 13:05
Man könnte auch die Frage lesen, den da steht MySQL!!
Markus Kinzler
  Mit Zitat antworten Zitat
arnof

Registriert seit: 25. Apr 2013
1.252 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#6

AW: SQL Automatisch zugeteilte Id ermitteln.

  Alt 14. Jul 2014, 15:03
Man könnte auch die Frage lesen, den da steht MySQL!!
Ich benutze zumeist MYSQL via ADO, da geht das in 95% der Fälle, manchmal aber auch nicht (bugs gibt es überall), dann hilft:

SELECT LAST_INSERT_ID()
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.546 Beiträge
 
Delphi 11 Alexandria
 
#7

AW: SQL Automatisch zugeteilte Id ermitteln.

  Alt 14. Jul 2014, 15:06
Womit wir dann wieder bei der allerersten Antwort wären
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Mikkey

Registriert seit: 5. Aug 2013
265 Beiträge
 
#8

AW: SQL Automatisch zugeteilte Id ermitteln.

  Alt 14. Jul 2014, 13:18
Was ist an Stele von <autoincrementfield> denn einzusetzen, das auf jedem DBMS funktioniert?
Natürlich das Feld der Tabelle, in das die erzeugte Zahl eingetragen wird.

Wenn das Feld "table.f1" das Primary Key Feld ist, ...
Bitte nichts lesen, was nicht geschrieben wurde!

f1 soll nicht primary Key sein, sondern lediglich eindeutiger Schlüssel.
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#9

AW: SQL Automatisch zugeteilte Id ermitteln.

  Alt 14. Jul 2014, 13:09
Die ganze Diskussion ist doch eigentlich unsinnig, denn
  1. Niemand bestreitet, dass ein RDBMS eine ID generieren kann
  2. Die Diskussion damit anfing, dass es Provider gab/gibt die es nicht schaffen diese vom RDBMS generierte ID zurück in das DataSet zu liefern.
    Beobachtetes Verhalten
    Der Datensatz war korrekt eingetragen, hatte vom RDBMS eine ID zugewiesen bekommen, aber im DataSet war dieser Datensatz immer noch mit leerem ID Feld. Um die ID zu erhalten musste das Dataset neu geladen werden und nun war das große Rätselraten, welcher Datensatz nun der war, der da gerade eingetragen wurde.
Irgendwie dreht sich der Kern dieser Diskussion darum, dass der eine meint, dass der andere meint, dass ein RDBMS keine IDs generiert, was aber niemand bezweifelt (1).

Das Thema geht eigentlich um Punkt (2) und der ist irgendwie nicht Thema der Diskussion ...

Sollte also der Provider es nicht schaffen die von MySQL (das ist das RDBMS dieses Themas) generierte ID zu liefern, dann geht man eben den folgenden Weg:
SQL-Code:
CREATE TABLE `foo` (
  `foo_id` int NOT NULL AUTO_INCREMENT ,
  `foo_value` varchar(50) NOT NULL ,
  PRIMARY KEY (`foo_id`) );
Delphi-Quellcode:
LQuery.SQL.Text := 'INSERT INTO foo (foo_value) VALUES (:foo_value); SELECT LAST_INSERT_ID() Foo_ID;';
LQuery.ParamByName('foo_value').Value := 'bar';
LQuery.Open;
LId := LQuery.FieldByName('Foo_ID').Value;
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)

Geändert von Sir Rufo (14. Jul 2014 um 13:14 Uhr)
  Mit Zitat antworten Zitat
supermuckl

Registriert seit: 1. Feb 2003
1.340 Beiträge
 
FreePascal / Lazarus
 
#10

AW: SQL Automatisch zugeteilte Id ermitteln.

  Alt 14. Jul 2014, 13:12
richtig!

aber genau das

Code:
LQuery.SQL.Text := 'INSERT INTO foo (foo_value) VALUES (:foo_value); SELECT LAST_INSERT_ID() Foo_ID;';
muss in einer multiuser DB in einer transaktion aufgerufen werden, soweit ich das richtig sehe
Das echte Leben ist was für Leute...
... die im Internet keine Freunde finden!
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 08:49 Uhr.
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