众所周知,MySQL LAST_INSERT_ID() 函数返回最新生成的序列号,但在多行插入的情况下,它将返回由最前面插入的行生成的序列号。
示例
mysql> Insert into Student(Name) values('Ram'),('Mohan'),('Aryan');
Query OK, 3 rows affected (0.03 sec)
Records: 3 Duplicates: 0 Warnings: 0
上面的查询借助多行插入查询在 Student 表中插入三个值。可以借助以下查询来检查列“Id”的值 -
mysql> Select * from Student;
+----+-------+
| Id | Name |
+----+-------+
| 1 | Raman |
| 2 | Rahul |
| 3 | Ram |
| 4 | Mohan |
| 5 | Aryan |
+----+-------+
5 rows in set (0.00 sec)
这意味着 Last_Insert_Id() 必须返回 5 作为输出,但我们可以看到它返回值 3,如下 -
mysql> Select Last_Insert_Id();
+------------------+
| Last_Insert_Id() |
+------------------+
| 3 |
+------------------+
1 row in set (0.00 sec)
它返回值 3,因为 3 是上述多行插入查询中最先插入的行的值。