Mysql
 sql >> Datenbank >  >> RDS >> Mysql

LAST_INSERT_ID() MySQL

Sie könnten die letzte Insert-ID in einer Variablen speichern:

INSERT INTO table1 (title,userid) VALUES ('test', 1); 
SET @last_id_in_table1 = LAST_INSERT_ID();
INSERT INTO table2 (parentid,otherid,userid) VALUES (@last_id_in_table1, 4, 1);    

Oder holen Sie sich die maximale ID aus Tabelle1 (EDIT:Warnung. Siehe Anmerkung in den Kommentaren von Rob Starling zu möglichen Fehlern durch Rennbedingungen bei Verwendung der maximalen ID)

INSERT INTO table1 (title,userid) VALUES ('test', 1); 
INSERT INTO table2 (parentid,otherid,userid) VALUES (LAST_INSERT_ID(), 4, 1); 
SELECT MAX(id) FROM table1;  

(Warnung:wie Rob Starling in der