kgfmb
Goto Top

Excel VBA Insert-Befehl auf Datenbank mit Rückgabe der ID des neuen Datensatzes

Wer kann helfen.

Hallo zusammen,

folgendes müsste ich noch realisieren.

Ich habe eine Excelsheet, in dem ich Daten aus einer Datenbank lese.
Wegen mehrfachzugriff.

Nun speichere ich mir die ID des Datensatzes beim Auslesen in die erste Spalte.
Ich bin soweit, auch einen neuen Datensatz in die Datenbank zu erstellen.
Jetzt würde ich aber gerne im nächsten Schritt auch gleich die neue erstellte ID auszulesen.

Weil ich per VBA bei jeder Zelländerung eine Speicherung erzeuge und vor Update die erste Zelle der Spalte (steht ja die ID)
auslese und auf dieser ein Update mache.

Welche Möglichkeiten gibt es, dies zu realisieren.

Vielleicht kann mir einer weiterhelfen.

MfG
KgFmB

Content-ID: 101527

Url: https://administrator.de/contentid/101527

Ausgedruckt am: 26.11.2024 um 01:11 Uhr

KgFmB
KgFmB 11.11.2008 um 14:10:35 Uhr
Goto Top
So hab mich jetzt erstmal damit beholfen, das ich nach dem INSERT gleich ein SELECT mit dem TOP 1 bzw. Limit 1 befehl.

wenn jedoch einer eine Alternativlösung hat.
Ich bin offen für alles.

MfG
KgFmB
solverone
solverone 11.11.2008 um 15:31:10 Uhr
Goto Top
Hallo,
falls du noch einen weiteren primary key als "ID" in der tabelle hast, dann würde ich darauf ein SELECT mit Where-Klausel machen.

Mike
KgFmB
KgFmB 11.11.2008 um 15:45:01 Uhr
Goto Top
Wäre auch eine Idee.
Aber wie erhalte ich von VBA aus den Key?
Ich mach einen einfaches "INSERT" und würd von dem erzeugten Datensatz die ID wieder zurückgeben.

Also mit dem Versuch TOP 1 bzw LIMIT 1 funktioniert es einwandfrei, muss halt hoffen, das nicht zwei User gleichzeitig einen Datensatz anlegen.
User A speichert
User B speichert
User A frägt den letzten Datensatz ab -> erhält die ID von User B
User B frägt den letzten Datensatz ab -> erhält die ID von User B

MfG
KgFmB
solverone
solverone 11.11.2008 um 15:49:17 Uhr
Goto Top
Also
insert into <tablename>(ID,Key2) Values(null,'was weiß ich')
so in der art sieht deine insert anweisung aus, wobei key2 der weitere primary key ist...
die ID bekommst du dann mit
SELECT ID FROM <tablename> WHERE Key2='was weiß ich'

und dann ist es wurscht, welcher benutzer inzwischen datensätze angelegt hat...

mike
KgFmB
KgFmB 18.11.2008 um 14:25:33 Uhr
Goto Top
Stimmt hast recht. Darauf bin ich gar nicht so gekommen. Ich kann dem si verwenden.
Danke.
Biber
Biber 18.11.2008 um 20:33:00 Uhr
Goto Top
Moin KgmB,

ich finde das zu kompliziert und die Vorstellung von zwei redundanten PrimaryKeys in einer Tabelle schlichtweg gruselig.
Es gibt doch in der Datenbank (Access? mySQL? Oracle? DB2?) offensichtlich ein Feld "ID" mit einer automatisch erzeugten eindeutigen Nummer (AutoWert oder AutoIncrement oder Sequence oder Identity oder wie es die Datenbank nennen mag.)
Und "normalerweise" oder zumindest wählbar kann dieser autmatisch generierte Wert doch aufsteigend festgelegt werden.

Wenn du also in der Datentabelle noch ein Feld "Username" anfügst mit dem Defaultwert des Usernamens (sei es des Datenbankusers oder des unter Windows angemeldeten Users =%username%), dann bekommst Du doch immer den jüngsten von diesem Benutzer angelegten Satz mit einer Abfrage:
"gib mit die höchste ID mit dem Usernamen des angemeldeten Users, oder auf SQLisch:
SELECT Max(ID) as UsersNeuesteID from TableX 
Where username=Environ('Username')  
[wenn es denn über VBA-Krams und den %username% der Windows-Umgebung sein soll.]
Oder bei "richtigen Datenbanken halt über das special register USERID, also den Datenbank-User.]

[Edit] Ergänzung:
Den ganzen neu(est)en Datensatz würdest Du z.B. so erhalten:
Select a.* FROM TableX a,
(SELECT max(id) as maxID FROM TableX 
WHERE username = Environ('USERNAME')) x  
WHERE a.id=x.maxID;
[/Edit]

Grüße
Biber