Monday 12 November 2018

MySQL LAST_INSERT_ID() used with multiple records INSERT statement

If I insert multiple records with a loop that executes a single record insert, 
the last insert id returned is, as expected, the last one. But if I do a multiple records 
insert statement:
INSERT INTO people (name,age)
VALUES ('William',25), ('Bart',15), ('Mary',12);
Let's say the three above are the first records inserted in the table. 
After the insert statement I expected the last insert id to return 3, but it returned 1. 
The first insert id for the statement in question.
So can someone please confirm if this is the normal behavior 
of LAST_INSERT_ID() in the context of multiple records INSERT statements. 
So I can base my code on it.

 Answers


he first inserted row only. The reason for this is to make it possible to reproduce 
easily the same INSERT statement against some other server.

0 comments:

Post a Comment