Zum Inhalt springen
View in the app

A better way to browse. Learn more.

Fachinformatiker.de

A full-screen app on your home screen with push notifications, badges and more.

To install this app on iOS and iPadOS
  1. Tap the Share icon in Safari
  2. Scroll the menu and tap Add to Home Screen.
  3. Tap Add in the top-right corner.
To install this app on Android
  1. Tap the 3-dot menu (⋮) in the top-right corner of the browser.
  2. Tap Add to Home screen or Install app.
  3. Confirm by tapping Install.

mySql: Insert > ID zurückgeben > Wie?

Empfohlene Antworten

Veröffentlicht

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

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

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.

<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>

<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>

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.

Antwort Test

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!

@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>

Archiv

Dieses Thema wurde archiviert und kann nicht mehr beantwortet werden.

Configure browser push notifications

Chrome (Android)
  1. Tap the lock icon next to the address bar.
  2. Tap Permissions → Notifications.
  3. Adjust your preference.
Chrome (Desktop)
  1. Click the padlock icon in the address bar.
  2. Select Site settings.
  3. Find Notifications and adjust your preference.