In this tutorial, we will learn how to fix MySQL issue “MySQL LAST_INSERT_ID() returning 0”.
Are you wondering why LAST_INSERT_ID() returned 0? We shall investigate the cause and fix this issue.
data:image/s3,"s3://crabby-images/35db8/35db84ae12c0d4017b879bfe0c3711d165d26939" alt="Fixing MySQL LAST_INSERT_ID() returning 0"
MySQL LAST_INSERT_ID() returns a non-negative id of the last inserted record when you have column with AUTO_INCREMENT attribute and the column is added to index.
We shall take an example table and investigate the process to solve the issue.
Consider the following students
table.
data:image/s3,"s3://crabby-images/5aaa4/5aaa4aacc385a1b7253418e04c88dcd468ef4f10" alt="MySQL - Solve LAST_INSERT_ID returns 0"
Now we shall add a column with AUTO_INCREMENT attribute.
data:image/s3,"s3://crabby-images/aa287/aa2871f55d12b33d3dc629e669c007d93d0a9b8e" alt="MySQL add column with AUTO_INCREMENT PRIMARY KEY"
Try inserting a row to students
table.
data:image/s3,"s3://crabby-images/5a5e3/5a5e389572ca502a0247b7bf72347ddd388069f7" alt="MySQL - Insert record into table"
Now as there is an AUTO_INCREMENT column that is added to INDEX, lets try the LAST_INSERT_ID() function.
data:image/s3,"s3://crabby-images/98fdc/98fdce9f6e670c53de02700056cc992f55b8529a" alt="MySQL LAST_INSERT_ID() function solved"