Zum Inhalt springen

mySql: Insert > ID zurückgeben > Wie?


Empfohlene Beiträge

Geschrieben

Geht um folgendes:

Ich hab zwei Tables, muss in beides was eintragen, benötige beim zweiten aber die ID (also zb "l_ka_id") des neuen Eintrags in der ersten Tabelle.

Wie geht das in mySQL, dass das Insert Statement die ID zurückgibt, beim MS Sql Server kann ich das ja mit einer Stored Procedure machen, aber wie in mySQL?

Bzw kann ich das ganze auch in ein Statement verpacken (erstellen eines neuen Eintrages in beiden Tables)?

Muss doch jemand wissen *g :)

Also dann, Thx & Ciao,

Sezz

Geschrieben

Hallo,

mir fällt da auf die schnelle nur der Umweg über eine Sequenz Tabelle ein.

CREATE TABLE seq_table (seq INT UNSIGNED NOT NULL)

INSERT INTO seq_table VALUES(0)

Als erstes setzt du nun die sequenz um eins hoch.

UPDATE seq_table SET seq = LAST_INSERT_ID(seq+1)

Diese ID kannst du jetzt über die Funktion LAST_INSERT_ID() abfragen.

INSERT INTO test1 SET myid = LAST_INSERT_ID()

INSERT INTO test2 SET myid = LAST_INSERT_ID()

Das ganze ist Client abhängig, d.h. auch wenn zwischen dem UPDATE und dem INSERT ein anderer Client wieder ein UPDATE ausführt, bekommt der erste Client bei LAST_INSERT_ID seine eigene ID und nicht die des zweiten Clients.

Gruß Jaraz

Geschrieben

<BLOCKQUOTE><font size="1" face="Verdana, Arial, Helvetica, sans-serif">Zitat:</font><HR>Original erstellt von JoelH:

<STRONG>Also ich glaube das Problem ist so einfach nicht mit MySQL zu lösen, ich lese einfach per SELECT den INSERT wieder ein und dann hab ich die ID für den anderen INSERT.</STRONG>

Geschrieben

<BLOCKQUOTE><font size="1" face="Verdana, Arial, Helvetica, sans-serif">Zitat:</font><HR>Original erstellt von JoelH:

<STRONG>Also ich glaube das Problem ist so einfach nicht mit MySQL zu lösen, ich lese einfach per SELECT den INSERT wieder ein und dann hab ich die ID für den anderen INSERT.</STRONG>

Geschrieben

Hallo,

<BLOCKQUOTE><font size="1" face="Verdana, Arial, Helvetica, sans-serif">Zitat:</font><HR>Also ich glaube das Problem ist so einfach nicht mit MySQL zu lösen, ich lese einfach per SELECT den INSERT wieder ein und dann hab ich die ID für den anderen INSERT.

Geschrieben

Endlich kann man wieder antworten :)

Schade dass es bei mySql (noch) keine einfacheren Lösungen gibt... Dann werd ich bei der 2. Tabelle halt einfach keinen Autowert nehmen, ist ja nicht so schlimm.

Trotzdem thx für die Anworten!

Geschrieben

@Jaraz

Deine Variante ist auch nicht gerade krativer ! MySQL hat ein paar Schwächen und das ist eine davon.

<FONT COLOR="#a62a2a" SIZE="1">[ 28. September 2001 07:06: Beitrag 2 mal editiert, zuletzt von JoelH ]</font>

Dein Kommentar

Du kannst jetzt schreiben und Dich später registrieren. Wenn Du ein Konto hast, melde Dich jetzt an, um unter Deinem Benutzernamen zu schreiben.

Gast
Auf dieses Thema antworten...

×   Du hast formatierten Text eingefügt.   Formatierung wiederherstellen

  Nur 75 Emojis sind erlaubt.

×   Dein Link wurde automatisch eingebettet.   Einbetten rückgängig machen und als Link darstellen

×   Dein vorheriger Inhalt wurde wiederhergestellt.   Editor leeren

×   Du kannst Bilder nicht direkt einfügen. Lade Bilder hoch oder lade sie von einer URL.

Fachinformatiker.de, 2024 by SE Internet Services

fidelogo_small.png

Schicke uns eine Nachricht!

Fachinformatiker.de ist die größte IT-Community
rund um Ausbildung, Job, Weiterbildung für IT-Fachkräfte.

Fachinformatiker.de App

Download on the App Store
Get it on Google Play

Kontakt

Hier werben?
Oder sende eine E-Mail an

Social media u. feeds

Jobboard für Fachinformatiker und IT-Fachkräfte

×
×
  • Neu erstellen...