Heim >Datenbank >MySQL-Tutorial >Wie erhalte ich die Zeilen-ID nach MySQL INSERT/UPDATE mit ON DUPLICATE KEY?

Wie erhalte ich die Zeilen-ID nach MySQL INSERT/UPDATE mit ON DUPLICATE KEY?

Patricia Arquette
Patricia ArquetteOriginal
2024-12-02 15:07:11957Durchsuche

How to Get the Row ID After MySQL INSERT/UPDATE with ON DUPLICATE KEY?

Zeilen-ID für INSERT/UPDATE mit ON DUPLICATE KEY abrufen

Frage:

Wie Können Sie die ID einer Zeile abrufen, nachdem Sie in MySQL ein INSERT oder UPDATE mit ON DUPLICATE KEY ausgeführt haben? ohne separate Abfragen ausführen zu müssen?

Antwort:

Um dies zu erreichen, können Sie die Funktion LAST_INSERT_ID(expr) als Workaround verwenden. Durch die Übergabe eines Ausdrucks an diese Funktion können Sie LAST_INSERT_ID für Aktualisierungen aussagekräftig machen.

Erklärung:

Wie in der verlinkten Dokumentation erwähnt (https://web.archive.org/web/20150329004325/https://dev.mysql.com/doc/refman/5.0/en/insert-on-duplicate.html), LAST_INSERT_ID() gibt normalerweise nur das ' zurück. insert'-ID für erfolgreiche INSERTs.

Allerdings durch Verwendung von LAST_INSERT_ID(expr) im ON Wenn Sie die DUPLICATE KEY UPDATE-Klausel verwenden, können Sie sie auch für Aktualisierungen aussagekräftig machen.

Wenn „id“ beispielsweise Ihre AUTO_INCREMENT-Spalte ist, können Sie Ihre Abfrage wie folgt ändern:

INSERT INTO table (a) VALUES (0)
ON DUPLICATE KEY UPDATE>

In diesem Fall gibt LAST_INSERT_ID(id) die aktualisierte ID zurück, wenn ein vorhandener Datensatz gefunden und aktualisiert wurde, oder die ID des neu eingefügten Datensatzes, wenn kein Duplikat vorhanden war gefunden.

Das obige ist der detaillierte Inhalt vonWie erhalte ich die Zeilen-ID nach MySQL INSERT/UPDATE mit ON DUPLICATE KEY?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn