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!